## **NEC**

## 初级用户手册

# 78K0/KF2

## 8-位单片微控制器

 $\mu$ PD78F0544  $\mu$ PD78F0545  $\mu$ PD78F0546  $\mu$ PD78F0547  $\mu$ PD78F0547D

 $\mu$ PD78F0547D 具有片上调试功能。

大规模生产时不要使用本产品,因为闪存可重写的次数是一定的,在使用片上调试功能后,不能保证它的可靠性。

文档编号 U17397EJ2V1UD00 (第二版)

发行日期 2005年7月N CP(K)

© NEC Electronics Corporation 2005

日本印制

## [备忘录]

## CMOS 设备注意事项

## ① 输入引脚处的电压波形

输入噪音或一个反射波引起的波形失真可能导致错误发生。如果由于噪音等的影响使CMOS设备的输入电压范围保持在VIL(MAX)和VIH(MIN)之间,设备可能发生错误。在输入电平固定时以及输入电平从VIL (MAX)过渡到VIH (MIN)时的传输期间,要防止散射噪声影响设备。

## ② 未使用的输入引脚的处理

CMOS设备的输入端保持开路可能导致误操作。如果一个输入引脚未被连接,则由于噪音等原因可能会产生内部输入电平,从而导致误操作。CMOS设备的操作特性与Bipolar或NMOS设备不同。CMOS设备的输入电平必须借助上拉或下拉电路固定在高电平或低电平。每一个未使用引脚都应该通过附加电阻连接到VDD或GND。如果有可能尽量定义为输出引脚。对未使用引脚的处理因设备而异,必须遵循与设备相关的规定和说明。

## ③ ESD防护措施

如果MOS设备周围有强电场,将会击穿氧化栅极,从而影响设备的运行。因此必须采取措施,尽可能防止静电产生。一旦有静电,必须立即释放。对于环境必须有适当的控制。如果空气干燥,应当使用增湿器。建议避免使用容易产生静电的绝缘体。半导体设备的存放和运输必须使用抗静电容器、抗静电屏蔽袋或导电材料容器。所有的测试和测量工具包括工作台和工作面必须良好接地。操作员应当佩戴静电消除手带以保证良好接地。不能用手直接接触半导体设备。对于装配有半导体设备的PW板也应采取类似的静电防范措施。

## ④ 初始化之前的状态

在上电时MOS设备的初始状态是不确定的。在刚刚上电之后,具有复位功能的MOS设备并没有被初始化。因此上电不能保证输出引脚的电平,I/O设置和寄存器的内容。设备在收到复位信号后才进行初始化。具有复位功能的设备在上电后必须立即进行复位操作。

## ⑤ 电源开关顺序

在一个设备的内部操作和外部接口使用不同的电源的情况下,按照规定,应先在接通内部电源之后再接通外部电源。当关闭电源时,按照规定,先关闭外部电源再关闭内部电源。如果电源开关顺序颠倒,可能会导致设备的内部组件过电压,产生异常电流,从而引起内部组件的误操作和性能的退化。

对于每个设备电源的正确开关顺序必须依据设备的规范说明分别进行判断。

## ⑥ 电源关闭状态下的输入信号

不要向没有加电的设备输入信号或提供I/O上拉电源。因为输入信号或提供I/O上拉电源将引起电流注入,从而引起设备的误操作,并产生异常电流,从而使内部组件退化。

每个设备电源关闭时的信号输入必须依据设备的规范说明分别进行判断。

EEPROM是NEC Electronics Corporation的商标。

Windows和WindowsNT是Microsoft Corporation在美国及其他国家的注册商标和商标。

PC/AT是International Business Machines Corporation的商标。

HP9000系列700和HP-UX是Hewlett-Packard Company的商标。

SPARCstation是SPARC International, Inc.的商标。

Solaris和SunOS是Sun Microsystems, Inc.的商标。

SuperFlash<sup>®</sup>是 Silicon Storage Technology, Inc.的一个注册商标,已经在美国和日本等几个国家使用。

注意事项:该产品使用的 SuperFlash®技术获得了 Silicon Storage Technology, Inc.公司的授权。

- 本文档信息先于产品的生产周期发布。在最终生产前,产品参数可能会有变化,或者 NEC Electronics Corporation 根据自身的判断在生产前撤消产品。
- 并非在每个国家都可获得全部型号的产品。请联系 NEC Electronics 销售代理,了解供货和其他相关信息。
- 未经NEC Electronics的书面许可,不能对本文档复制。本文档出现的任何错误,NEC Electronics不承担责任。
- 如果用户在使用本文档列出的 NEC Electronics 半导体产品或通过其他途径使用这些产品时,产生侵犯专利、版权以及其他侵犯第三方知识产权的行为,NEC Electronics 不承担责任。对于 NEC Electronics 及其他子公司的任何专利、版权以及其他知识产权,NEC Electronics 没有以许可、明示、暗示以及其他任何方式授权。
- 文档中电路、软件和其他相关信息的描述,用来说明半导体产品操作和应用的例子。客户在使用这些电路、 软件和信息时负全责。客户或第三方在使用这些电路、软件和信息时造成的损失,NEC Electronics不承担责 任。
- NEC Electronics尽力提高半导体产品的质量、可靠性和安全性,但请客户理解错误是不可能完全避免的。为了尽可能减少由于NEC Electronics半导体产品所带来的个人财产及人身安全(包括死亡)的风险,客户在设计过程中应加强安全措施,如容错、耐火性和自检等。
- NEC Electronics产品分为以下三个质量等级:
  - "标准"、"专业"、"特级"。"特级"质量等级仅用于客户定制的半导体产品。一种半导体产品的应用主要依据它的质量等级。客户在使用某种半导体产品之前应先了解它的质量等级。
- "标准": 计算机,办公设备,通信设备,测试设备,视频音频设备,家用电子产品,机械工具,个人电子设备和工业机器人
- "专业":运输设备(汽车,火车,轮船等),交通控制系统,防灾系统,反犯罪系统,安全设备和医疗设备 (不是专用于生命救护的设备)
- "特级": 飞机, 航空设备, 水下中继器, 核反应堆控制系统, 生命救护系统和用于生命救护的医疗设备等。除非在NEC Electronics规格书或规格手册中特别规定, 一般的NEC Electronics产品的质量等级都是"标准"的。如果客户希望在不受NEC Electronics产品应用限制的条件下使用NEC Electronics半导体产品, 必须事先与NEC Electronics销售代理联系, 以确定NEC Electronics是否支持该应用环境。(注释)
- (1) "NEC Electronics" 在这里是指NEC Electronics Corporation和它的主要子公司。
- (2) "NEC Electronics半导体产品"是指由NEC Electronics或为NEC Electronics开发和制造的半导体产品(如上述定义)。

M8F 02 11-1

## 地区信息

本文档中的某些信息可能因国家不同而有所差异。用户在使用任何一种NEC Electronics产品之前,请与当地的NEC Electronics办事处联系,以获取权威的代理商和发行商信息。请验证以下内容:

- 设备的可靠性
- 订货信息
- 产品发布讲度表
- 相关技术资料的可用性
- 开发环境规格(例如,要求第三方开发工具和设备规格,主计算机,电源插头,AC供电电压等)
- 网络要求

此外,对于商标、注册商标、出口限制条款和其他法律规定,不同的国家也有不同的要求。

## 【全球支援】

http://www.necel.com/en/support/support.html

Santa Clara, California Tel: 408-588-6000 800-366-9782

Duesseldorf, Germany Tel: 0211-65030

> • Sucursal en España Madrid, Spain

Tel: 091-504 27 87

• Succursale Française Vélizy-Villacoublay, France

Tel: 01-30-675800

• Filiale Italiana

Milano, Italy Tel: 02-66 75 41

• Branch The Netherlands

Eindhoven, The Netherlands Tel: 040-265 40 10

• Tyskland Filial

Taeby, Sweden Tel: 08-63 87 200

• United Kingdom Branch

Milton Keynes, UK Tel: 01908-691-133

NEC Electronics America, Inc. (U.S.) NEC Electronics (Europe) GmbH NEC Electronics Hong Kong Ltd.

Hong Kong Tel: 2886-9318

**NEC Electronics Hong Kong Ltd.** 

Seoul Branch Seoul. Korea Tel: 02-558-3737

**NEC Electronics Shanghai Ltd.** 

Shanghai, P.R. China Tel: 021-5888-5400

**NEC Electronics Taiwan Ltd.** 

Taipei, Taiwan Tel: 02-2719-2377

**NEC Electronics Singapore Pte. Ltd.** 

Novena Square, Singapore Tel: 6253-8311

J05.6

## 引言

读者对象

本手册于适用那些希望了解 78K0/KF2 功能,并设计开发应用系统和程序的工程师。目标产品如下。

78K0/KF2: μPD78F0544, 78F0545, 78F0546, 78F0547, 78F0547D

目的

本手册用于帮助用户了解下面组件中描述的功能。

组件

78K0/KF2 手册主要分为两个部分:手册和指令(与78K/0系列通用)。

78K0/KF2 用户手册 (本手册) 78K/0 系列 用户手册 指令

- 引脚功能
- 内部模块功能
- 中断
- 其它内置外设功能
- 电子产品规范(目标)

- CPU 功能
- 指令集
- 指令扩展

手册使用方法

在阅读本手册前,读者应掌握电子工程、逻辑电路和微控制器等方面的一般知识。

- 如果读者要了解产品功能:
  - → 请按**目录**顺序阅读本手册。标识★处是主要修改的地方。
- 如何解释寄存器格式:
  - $\rightarrow$  括号中的位名在 RA78K0 中被定义为保留字,并且在 CC78K0 中直接通过 #pragma sfr 定义为一个 sfr 变量。
- 如果读者希望了解某寄存器的详细信息:
  - → 可参阅**附录 C 寄存器索引。**
- 如果读者希望了解 78K/0 系列指令的详细信息:
  - → 可参阅 78K/0 系列指令用户手册(U12326E)。

规定 数据规则: 数据的高位部分在左边,低位部分在右边

 有效低电平表示法:
 xxx (在引脚和信号名称上划一条线)

 注:
 文中用注标注的相关术语的脚注

注意事项: 需要特别关注的信息

**备注**: 补充信息

数的表示法: 二进制 ····×××× 或 ××××B

十进制 ····×××× 十六进制 ····××××H

**相关文档** 本手册中指出的相关文档可能包括了初级的版本,但未注明。

## 设备文档

| 文档名称           | 文档编号    |
|----------------|---------|
| 78K0/KF2 用户手册  | 本手册     |
| 78K/0 系列指令用户手册 | U12326E |

## 开发工具(软件)文档(用户手册)

| 3                         | 文档名称        | 文档编号    |
|---------------------------|-------------|---------|
| RA78K0 Ver. 3.80 汇编包      | 操作          | U17199E |
|                           | 语言          | U17198E |
|                           | 结构化汇编语言     | U17197E |
| CC78K0 Ver. 3.70 C 编译器    | 操作          | U17201E |
|                           | 语言          | U17200E |
| SM+系统仿真器                  | 操作          | U17246E |
|                           | 开放式外部用户接口规范 | U17247E |
| ID78K0-QB Ver. 2.90 集成调试器 | 操作          | U17437E |
| PM+ Ver. 5.20             |             | U16934E |

## 开发工具(硬件)文档 (用户手册)

| 文档名称                | 文档编号    |
|---------------------|---------|
| QB-78K0KX2 在线仿真器    | U17341E |
| QB-78K0MINI 片上调试仿真器 | U17029E |

## 与闪存编程相关的文档

| 文档名称             | 文档编号    |
|------------------|---------|
| PG-FP4 闪存编程器用户手册 | U15260E |

注意事项 以上列出的相关文档可能在未通知的情况下被修改,在设计时请使用每个文档的最新版本。

## 其他文档

| 文档名称                | 文档编号    |
|---------------------|---------|
| 半导体选择指南一产品和封装一      | X13769X |
| 半导体设备安装手册           | 注       |
| NEC 半导体设备质量等级       | C11531E |
| NEC 半导体设备可靠性/质量控制系统 | C10983E |
| 半导体设备防静电 ESD 保护指南   | C11892E |

注 浏览"半导体设备安装手册"网站(http://www.necel.com/pkg/en/mount/index.html).

注意事项 以上列出的相关文档可能在未通知的情况下被修改,在设计时请使用每个文档的最新版本。

## 目 录

| 第一章 | 概述                                             | 17 |
|-----|------------------------------------------------|----|
| 1.1 | 特征                                             | 17 |
| 1.2 | 应用                                             | 18 |
| 1.3 | 定购信息                                           | 19 |
| 1.4 | 引脚配置(俯视图)                                      | 20 |
| 1.5 | 78K0/Kx2 系列介绍                                  | 22 |
| 1.6 | 框图                                             | 25 |
| 1.7 | 功能概述                                           | 26 |
| 第二章 | 引脚功能                                           | 28 |
| 2.1 | 引脚功能列表                                         | 28 |
| 2.2 | 引脚功能描述                                         | 32 |
|     | 2.2.1 P00 至 P06 (端口 0)                         | 32 |
|     | 2.2.2 P10 至 P17(端口 1)                          | 33 |
|     | 2.2.3 P20 至 P27 (端口 2)                         | 34 |
|     | 2.2.4 P30 至 P33 (端口 3)                         | 34 |
|     | 2.2.5 P40 至 P47 (端口 4)                         | 35 |
|     | 2.2.6 P50 至 P57 (端口 5)                         | 35 |
|     | 2.2.7 P60 至 P67 (端口 6)                         | 35 |
|     | 2.2.8 P70 至 P77 (端口 7)                         |    |
|     | 2.2.9 P120 至 P124 (端口 12)                      |    |
|     | 2.2.10 P130(端口 13)                             |    |
|     | 2.2.11 P140 至 P145(端口 14)                      |    |
|     | 2.2.12 AVREF                                   |    |
|     | 2.2.13 AVss                                    |    |
|     | 2.2.14 RESET                                   |    |
|     | 2.2.15 REGC                                    |    |
|     | 2.2.16 V <sub>DD</sub> and EV <sub>DD</sub>    |    |
|     | 2.2.17 Vss 和 EVss                              |    |
| 2.3 | 32.18 FLMD0                                    |    |
| 2.5 | <b>打牌 10</b> 电晶和不仅用 打牌的是以是该为                   |    |
| 第三章 | CPU结构                                          | 43 |
| 3.1 | 存储空间                                           | 43 |
|     | 3.1.1 内部程序存储空间                                 | 49 |
|     | 3.1.2 存储器组 (仅用于µPD78F0546, 78F0547 和 78F0547D) | 50 |
|     | 3.1.3 内部数据存储空间                                 | 51 |
|     | 3.1.4 特殊功能寄存器(SFR)区域                           | 51 |
|     | 3.1.5 数据存储空间寻址                                 |    |
| 3.2 | 处理器寄存器                                         | 56 |
|     | 3.2.1 控制寄存器                                    |    |
|     | 3.2.2 通用寄存器                                    | 60 |

|   |             | 3.2.3 特殊功能寄存器 (SFR)                          | 61  |
|---|-------------|----------------------------------------------|-----|
|   | 3.3         | 指令地址寻址                                       | 66  |
|   |             | 3.3.1 相对寻址                                   | 66  |
|   |             | 3.3.2 立即寻址                                   | 67  |
|   |             | 3.3.3 表间接寻址                                  | 68  |
|   |             | 3.3.4 寄存器寻址                                  | 68  |
|   | 3.4         | 操作数地址寻址                                      | 69  |
|   |             | 3.4.1 隐含寻址                                   | 69  |
|   |             | 3.4.2 寄存器寻址                                  | 70  |
|   |             | 3.4.3 直接寻址                                   |     |
|   |             | 3.4.4 短直接寻址                                  |     |
|   |             | 3.4.5 特殊功能寄存器 (SFR)寻址                        |     |
|   |             | 3.4.6 寄存器间接寻址                                |     |
|   |             | 3.4.7 基址寻址                                   |     |
|   |             | 3.4.8 基址变址寻址                                 |     |
|   |             | 3.4.9 堆栈寻址                                   | 77  |
| * | 第四章         | 存储器组选择功能 (仅用于μPD78F0546, 78F0547 和 78F0547D) | 78  |
|   |             | 存储器组                                         |     |
|   |             |                                              |     |
|   | 4.3         | 选择存储器组                                       | 80  |
|   |             | 4.3.1 存储器组之间的关联值                             | 80  |
|   |             | 4.3.2 存储器组之间的指令转移                            | 82  |
|   |             | 4.3.3 存储器组之间的子程序调用                           | 84  |
|   |             | 4.3.4 通过中断将指令转向存储器组区域                        | 86  |
|   | 第五章         | 端口功能                                         | 88  |
|   | 5.1         | 端口功能                                         | 88  |
|   |             | 端口设置                                         |     |
|   | <b>0.</b> 2 | 5.2.1 端口 0                                   |     |
|   |             | 5.2.2 端口 1                                   |     |
|   |             | 5.2.3 端口 2                                   |     |
|   |             | 5.2.4 端口 3                                   |     |
|   |             | 5.2.5 端口 4                                   | 103 |
|   |             | 5.2.6 端口 5                                   | 104 |
|   |             | 5.2.7 端口 6                                   | 105 |
|   |             | 5.2.8 端口 7                                   | 108 |
|   |             | 5.2.9 端口 12                                  | 109 |
|   |             | 5.2.10 端口 13                                 | 111 |
|   |             | 5.2.11 端口 14                                 | 112 |
|   | 5.3         | 控制端口功能的寄存器                                   | 116 |
|   | 5.4         | 端口功能操作                                       | 121 |
|   |             | 5.4.1 写入 I/O端口                               | 121 |
|   |             | 5.4.2 从 I/O端口读取                              | 121 |
|   |             | 5.4.3 I/O端口的操作                               | 121 |
|   | 5.5         | 使用复用功能时端口模式寄存器和输出锁存器的设置                      | 122 |
|   | 笙六音         | 时钟发生器                                        | 125 |

|          | 6.1 | 时钟发生器的功能                            | 125 |
|----------|-----|-------------------------------------|-----|
|          | 6.2 | 时钟发生器的构成                            | 126 |
|          | 6.3 | 控制时钟发生器的寄存器                         | 128 |
|          | 6.4 | 系统时钟振荡器                             | 137 |
|          |     | 6.4.1 X1 振荡器                        |     |
|          |     | 6.4.2 XT1 振荡器                       |     |
|          |     | 6.4.3 不使用子系统时钟                      |     |
|          |     | 6.4.4 内部高速振荡器                       |     |
|          |     | 6.4.5 内部低速振荡器                       |     |
|          |     | 6.4.6 预分频器                          |     |
|          | 6.5 | 4 4 1 2 4 10 11 4 4 1 1 1 1         |     |
|          | 6.6 | 时钟控制                                |     |
|          |     | 6.6.1 高速系统时钟控制                      |     |
|          |     | 6.6.2 控制内部高速振荡时钟示例                  |     |
|          |     | 6.6.3 控制子系统时钟示例                     |     |
|          |     | 6.6.4 控制内部低速振荡时钟示例                  |     |
|          |     | 6.6.5 CPU和外部硬件所采用的时钟                |     |
|          |     | 6.6.6 CPU 时钟状态转换图                   |     |
|          |     | 6.6.7 CPU时钟切换之前的状况与切换之后的处理          |     |
| <b>k</b> |     | 6.6.8 CPU时钟和主系统时钟切换所需的时间            |     |
| <b>t</b> |     | 6.6.9 时钟振荡停止前的状况                    |     |
|          |     | 16 位定时器/事件计数器 00 和 01               |     |
|          |     | 16 位定时器/事件计数器 00 和 01 的切能           |     |
|          |     | 控制 16 位定时器/事件计数器 00 和 01 的寄存器       |     |
|          |     | 16 位定时器/事件计数器 00 和 01 的操作           |     |
|          | 7   | 7.4.1 间隔定时器的操作                      |     |
|          |     | 7.4.2 方波输出操作                        |     |
|          |     | 7.4.3 外部事件计数器的操作                    |     |
|          |     | 7.4.4 清零&启动模式(通过Tl00n引脚有效沿输入进入)下的操作 |     |
|          |     | 7.4.5 自由运行定时器操作                     |     |
|          |     | 7.4.6 PPG输出操作                       | 209 |
|          |     | <b>7.4.7</b> 单脉冲输出操作                | 212 |
|          |     | 7.4.8 脉冲宽度测量操作                      | 217 |
|          | 7.5 | TM0n的特殊用途                           | 225 |
|          |     | 7.5.1 TMOn 操作期间重写CR01n              | 225 |
|          |     | 7.5.2 LVS0n和LVR0n的设置                | 225 |
|          | 7.6 | 16 位定时器/事件计数器 00 和 01 注意事项          | 227 |
|          |     | 8 位定时器/事件计数器 50 和 51                |     |
|          | 8.1 | 8 位定时器/事件计数器 50 和 51 的功能            | 231 |
|          | 8.2 | 8 位定时器/事件计数器 50 和 51 的构成            | 231 |
|          |     | 控制 8 位定时器/事件计数器 50 和 51 的寄存器        |     |
|          | 8.4 | 8 位定时器/事件计数器 50 和 51 的操作            | 239 |
|          |     | 8.4.1 用作间隔定时器                       | 239 |
|          |     | 8.4.2 田作外部事件计数哭                     | 241 |

|       | 8.4.3 方波输出操作                  | 242 |
|-------|-------------------------------|-----|
|       | 8.4.4 PWM输出操作                 | 243 |
| 8.5 1 | 使用 8 位定时器/事件计数器 50 和 51 的注意事项 | 247 |
|       |                               |     |
| 第九章   | 8 位定时器 H0 和 H1                | 248 |
| 9.1   | 8 位定时器H0 和 H1 的功能             | 248 |
| 9.2   | 8 位定时器H0 和H1 的配置              | 248 |
| 9.3   | 控制 8 位定时器H0 和H1 的寄存器          | 252 |
| 9.4   | 8 位定时器H0 和H1 的操作              | 257 |
|       | 9.4.1 间隔定时器/方波输出操作            | 257 |
|       | 9.4.2 PWM输出操作                 |     |
|       | 9.4.3 载波发生器操作 (仅用于 8 位定时器H1)  | 266 |
| 第十章   | 钟表定时器                         | 273 |
| 10.1  | 钟表定时器的功能                      | 273 |
| 10.2  | 钟表定时器的配置                      | 274 |
| 10.3  | 控制钟表定时器的寄存器                   | 275 |
| 10.4  | 钟表定时器操作                       | 277 |
|       | 10.4.1 钟表定时器操作                | 277 |
|       | 10.4.2 间隔定时器操作                | 277 |
| 10.5  | 钟表定时器使用注意事项                   | 278 |
| 第十一章  | <b>适 看门狗定时器</b>               | 279 |
| 11.1  | 看门狗定时器的功能                     | 279 |
| 11.2  | 看门狗定时器的配置                     | 280 |
| 11.3  | 控制看门狗定时器的寄存器                  | 281 |
| 11.4  | 看门狗定时器操作                      | 281 |
|       | 11.4.1 看门狗定时器操作的控制            |     |
|       | 11.4.2 看门狗定时器溢出时间的设置          |     |
|       | 11.4.3 看门狗定时器窗口打开周期的设置        | 284 |
| 第十二章  | € 时钟输出/蜂鸣器输出控制器               | 286 |
| 12.1  | 时钟输出/蜂鸣器输出控制器的功能              | 286 |
| 12.2  | 时钟输出/蜂鸣器输出控制器的配置              | 287 |
| 12.3  | 控制时钟输出/蜂鸣器输出控制器的寄存器           | 287 |
| 12.4  | 时钟输出/蜂鸣器输出控制器的操作              |     |
|       | 12.4.1 时钟输出操作                 |     |
|       | 12.4.2 蜂鸣器输出操作                | 289 |
| 第十三章  | A/D转换器                        | 290 |
| 13.1  | A/D转换器的功能                     | 290 |
|       | A/D转换器的配置                     |     |
|       | A/D转换器使用的寄存器                  |     |
| 13.4  | A/D转换器的操作                     |     |
|       | 13.4.1 A/D转换器的基本操作            |     |
|       | 13.4.2 输入由压和转换结果              | 303 |

|              | 13.4.3 A/D转换器操作模式              | 304 |
|--------------|--------------------------------|-----|
| 13.5         | A/D转换器特征表的阅读方法                 | 306 |
| 13.6         | A/D转换器使用注意事项                   | 308 |
|              |                                |     |
| 第十四章         | : 串行接口UART0                    | 312 |
| 14.1         | 串行接口UART0 的功能                  | 312 |
| 14.2         | 串行接口UARTO 的配置                  |     |
| 14.3         | 控制串行接口UART0 的寄存器               |     |
| 14.4         | 串行接口UARTO 的操作                  |     |
|              | 14.4.1 操作停止模式                  |     |
|              | 14.4.2 异步串行接口 (UART)模式         |     |
|              | 14.4.3 专用波特率发生器                |     |
| <b>公上工</b> 会 | : 串行接口UART6                    | 222 |
|              |                                |     |
|              | 串行接口UART6 的功能                  |     |
|              | 串行接口UART6 的配置                  |     |
|              | 控制串行接口UART6 的寄存器               |     |
| 15.4         | 串行接口UART6 的操作                  |     |
|              | 15.4.1 操作停止模式                  |     |
|              | 15.4.2 异步串行接口(UART)模式          |     |
|              | 15.4.3 专用波特率发生器                | 363 |
| 第十六章         | = 串行接口CSI10 和CSI11             | 370 |
| 16.1         | 串行接口 CSI10 和CSI11 的功能          | 370 |
|              | 串行接口CSI10 和CSI11 的配置           |     |
|              | 控制串行接口CSI10 和CSI11 的寄存器        |     |
| 16.4         | 串行接口CSI10 和CSI11 的操作           | 378 |
|              | 16.4.1 操作停止模式                  | 378 |
|              | 16.4.2 3 线串行I/O模式              | 379 |
| 第十七章         | : 串行接口CSIA0                    | 391 |
| 17.1         | 串行接口CSIA0 的功能                  | 391 |
| 17.2         | 串行接口CSIA0 的配置                  | 392 |
| 17.3         | 控制串行接口CSIA0 的寄存器               | 394 |
| 17.4         | 串行接口CSIA0 的操作                  | 403 |
|              | 17.4.1 操作停止模式                  | 403 |
|              | 17.4.2 3线串行I/O模式               | 404 |
|              | 17.4.3 具有自动发送/接收功能的 3 线串行I/O模式 | 409 |
| 第十八章         | : 串行接口 IIC0                    | 429 |
| 18.1         | 串行接口 <b>IIC0</b> 的功能           | 429 |
|              | 串行接口 IIC0 的配置                  |     |
|              | 控制串行接口 IIC0 的寄存器               |     |
|              | I <sup>2</sup> C 总线模式功能        |     |
|              | 18.4.1 引脚配置                    |     |
| 18.5         | I <sup>2</sup> C总线定义和控制方法      |     |

|              | 18.5.1 起始条件                                | 449 |
|--------------|--------------------------------------------|-----|
|              | 18.5.2 地址                                  | 450 |
|              | 18.5.3 传送方向指示                              | 450 |
|              | 18.5.4 应答信号 (ACK)                          | 451 |
|              | 18.5.5 停止条件                                | 452 |
|              | 18.5.6 等待                                  | 453 |
|              | 18.5.7 取消等待                                | 455 |
|              | 18.5.8 中断请求 (INTIIC0)产生时序和等待控制             | 455 |
|              | 18.5.9 地址匹配的检测方法                           |     |
|              | 18.5.10 错误检测                               | 456 |
|              | 18.5.11 扩展码                                | 457 |
|              | 18.5.12 仲裁                                 | 458 |
|              | 18.5.13 唤醒功能                               | 459 |
|              | 18.5.14 通信预约                               | 460 |
|              | 18.5.15 其他注意事项                             | 463 |
|              | 18.5.16 通信操作                               | 465 |
|              | 18.5.17 I <sup>2</sup> C中断请求 (INTIICO)产生时序 | 472 |
| 18.6         | 时序图                                        |     |
|              |                                            |     |
| 第十九章         | : 乘法器/除法器                                  | 500 |
| 10.1         | 乘法器/除法器的功能                                 | 500 |
|              | 乘法器/除法器的配置                                 |     |
|              | 控制乘法器/除法器的寄存器                              |     |
|              | 乘法器/除法器的操作                                 |     |
| 13.4         | 19.4.1 乘法操作                                |     |
|              | 19.4.2 除法操作                                |     |
|              | 19.4.2 际法保作                                | 507 |
| <b>给一</b> 上音 | ·<br>: 中断功能                                | 500 |
|              |                                            |     |
|              | 中断功能的类型                                    |     |
|              | 中断源及配置                                     |     |
|              | 控制中断功能的寄存器                                 |     |
| 20.4         | 中断服务操作                                     |     |
|              | 20.4.1 可屏蔽的中断响应                            |     |
|              | 20.4.2 软件中断请求响应                            |     |
|              | 20.4.3 中断嵌套                                | 525 |
|              | 20.4.4 保持中断请求                              | 528 |
|              |                                            |     |
| 第二十一         | ·章 按键中断功能                                  | 529 |
| 21.1         | 按键中断功能                                     | 529 |
|              | 按键中断的配置                                    |     |
|              | 控制按键中断的寄存器                                 |     |
|              |                                            |     |
| 第二十二         | 章 待机功能                                     | 531 |
| 22.4         | <b>待机功能及配置</b>                             | E94 |
| <b>22.</b> I |                                            |     |
|              | 22.1.1 待机功能                                |     |
| 22.0         | 22.1.2 控制待机功能的寄存器                          |     |
| <b>ZZ.Z</b>  | 待机功能的操作                                    |     |

|                | 22.2.1 HALT模式                         | 534 |
|----------------|---------------------------------------|-----|
|                | 22.2.2 STOP模式                         | 539 |
|                |                                       |     |
| 第二十三           | E章 复位功能                               | 544 |
| 22.1           | 确认复位源的寄存器                             | 552 |
| 23.1           | 佣队及位你们可付备                             |     |
| <b>笙</b> 一十爪   | ]章 上电清零电路                             | 553 |
|                |                                       |     |
|                | 上电清零电路的功能                             |     |
|                | 上电清零电路的配置                             |     |
|                | 上电清零电路的操作                             |     |
| 24.4           | 上电清零电路使用注意事项                          | 557 |
| <i>₩</i> → 1 ⊤ | ····································· | 550 |
|                | 〔章   低电压检测电路                          |     |
| 25.1           | 低电压检测电路的功能                            | 559 |
| 25.2           | 低电压检测电路的配置                            | 559 |
| 25.3           | 控制低电压检测电路的寄存器                         | 560 |
| 25.4           | 低电压检测电路的操作                            | 563 |
|                | 25.4.1 用于复位                           | 564 |
|                | 25.4.2 用于中断                           |     |
| 25.5           | 低电压检测电路的注意事项                          | 574 |
|                |                                       |     |
| 第二十六           | <del>、</del> 章 选项字节                   | 577 |
| 26.1           | 选项字节的功能                               | 577 |
| 26.2           | 选项字节的格式                               | 578 |
|                |                                       |     |
| 第二十七           | ː章 闪存                                 | 581 |
| 27.1           | 内部存储器容量切换寄存器                          | 581 |
|                | 内部扩展RAM容量切换寄存器                        |     |
|                | 用闪存编程器写入数据                            |     |
|                | 编程环境                                  |     |
|                | 通信模式                                  |     |
|                | 在线方式的引脚连接                             |     |
|                | 27.6.1 FLMD0 引脚                       |     |
|                | 27.6.2 串行接口引脚                         |     |
|                | 27.6.3 RESET 引脚                       |     |
|                | 27.6.4 端口引脚                           |     |
|                | 27.6.5 REGC引脚                         |     |
|                | 27.6.6 其它信号引脚                         |     |
|                | 27.6.7 供电电压                           |     |
| 27.7           | 编程方法                                  |     |
|                | 27.7.1 控制闪存                           |     |
|                | 27.7.2 闪存编程模式                         |     |
|                | 27.7.3 选择通信模式                         |     |
|                | 27.7.4 通信命令                           |     |
| 27.8           | 安全性设置                                 |     |
|                | 通讨自编程进行闪存编程                           |     |

|      | 27.9.1 引导交换功能                              | 598 |
|------|--------------------------------------------|-----|
| 第二十  | 八章 片上调试功能 <b>(</b> 仅用于 <b>μPD78F0547D)</b> | 600 |
| 28.1 | 1 片上调试安全 ID                                | 601 |
| 第二十二 | 九章 指令集                                     | 602 |
| 29.1 | 1 操作列表使用规则                                 | 602 |
|      | 29.1.1 操作数标识符和标识方法                         |     |
|      | 29.1.2 操作栏描述                               | 603 |
|      | 29.1.3 标志操作栏的描述                            | 603 |
| 29.2 | 2 操作列表                                     | 604 |
| 29.3 | 3 按寻址类型列出指令                                | 612 |
| 第三十章 | 章 电子产品规范(目标系统)                             | 615 |
| 第三十- | 一章                                         | 635 |
| 第三十二 | 二章 等待注意事项                                  | 637 |
|      | 1 等待注意事项                                   |     |
|      | 1                                          |     |
| 32.2 | 2 广生等付的介命硬件                                |     |
| 附录 A | 开发工具                                       | 640 |
|      | 软件包                                        |     |
|      |                                            |     |
|      | - 冶 目                                      |     |
|      | 闪存写入工具                                     |     |
|      | 5 调试工具 (硬件)                                |     |
| ,    | A.5.1 当使用在线仿真器 QB-78K0KX2 时                |     |
|      | A.5.2 当使用片上调试仿真器 QB-78K0MINI 时             |     |
| A.6  | <b>6</b> 调试工具(软件)                          |     |
| 附录 B | 目标系统设计的注解                                  | 647 |
| 附录 C | 寄存器索引                                      | 649 |
| C.1  | 寄存器索引 (按寄存器名称的字母顺序排列)                      | 649 |
|      | 2 寄存器索引 (按寄存器符号的字母顺序排列)                    |     |
| 附录 D | 修订历史                                       | 657 |
| D.1  | 本版中主要修订之处                                  | 657 |
|      |                                            |     |

## 第一章 概述

## 1.1 特征

- O 指令最短执行时间可以在高速(0.1 μs: @ 高速系统时钟的操作频率为 20 MHz) 和超低速(122 μs: @子系统时钟的操作频率为 32.768 kHz)之间改变
- 〇 通用寄存器: 8 位 × 32 个寄存器(8 位× 8 个寄存器× 4 组)
- O ROM, RAM 的容量

| 项目                   | 程序存储            | 器      | 数据存储器                 |                       |  |  |
|----------------------|-----------------|--------|-----------------------|-----------------------|--|--|
| 产品型号                 | (ROM)           |        | 内部高速 RAM <sup>推</sup> | 内部扩展 RAM <sup>推</sup> |  |  |
| μPD78F0544           | 闪存 <sup>推</sup> | 48 KB  | 1 KB                  | 1 KB                  |  |  |
| μPD78F0545           |                 | 60 KB  |                       | 2 KB                  |  |  |
| μPD78F0546           |                 | 96 KB  |                       | 4 KB                  |  |  |
| μPD78F0547, 78F0547D |                 | 128 KB |                       | 6 KB                  |  |  |

- 注: 通过使用内存容量切换寄存器(IMS)和内部扩展 RAM 容量切换寄存器(IXS),可以改变内部闪存,内部高速 RAM 容量和内部扩展 RAM 的容量。要了解 IMS 和 IXS,请参考 27.1 内存容量切换寄存器 和 27.2 内部 扩展 RAM 容量切换寄存器。
- O 缓冲 RAM: 32 字节(可用于 CSI 模式的传送,具有自动发送/接收功能)
- O 内置单电源闪存
- O 自编程(具有启动交换功能)
- O 片上调试功能(仅用于μPD78F0547D)<sup>±</sup>
- O 内置上电清零(POC)电路和低电压检测器(LVI)
- O 内置看门狗定时器(使用内置的内部低速振荡时钟进行操作)
- O 内置乘法器/除法器(16 位 × 16 位, 32 位 / 16 位)
- O 内置按键中断功能
- O 内置时钟输出/蜂鸣器输出控制器
- O I/O 端口: 71 (N-ch 漏极开路: 4)
- O 定时器: 8通道
  - 16 位定时器/事件计数器: 2 通道
    8 位定时器/事件计数器: 2 通道
    8 位定时器: 2 通道
    钟表定时器: 1 通道
    看门狗定时器: 1 通道
- ★ **注:** μPD78F0547D 具有片上调试功能。大规模生产时不要使用本产品,因为在使用片上调试功能后,从闪存可 重写的次数受到限制这一点来看,它的可靠性不能保证。NEC Electronics 不接受对于本产品的任何投诉。

- O 串行接口: 5 通道
  - UART (支持 LIN (本地互联网络)- 总线:
- 1通道

CSI/UART <sup>注</sup>:

1 通道

• CSI:

1 通道

• 具有自动收发功能的 CSI:

1通道

• I<sup>2</sup>C:

- 1通道
- O 10 位分辨率 A/D 转换器(AVREF = 2.3 ~ 5.5 V): 8 通道
- O 供电电压: VDD = 1.8 ~ 5.5 V
- O 工作环境温度:
  - T<sub>A</sub> = −40 ~ +85°C: (T), (S), (R) 产品
  - T<sub>A</sub> = −40 ~ +125°C: (T2) 产品
  - 注: 选择这些复用功能引脚中的任意一种功能。

## 1.2 应用

- ★ 汽车设备((A), (A1), (A2)级产品,正在开发中)
  - 车身电子系统控制(电动门窗,车门开关接收等)
  - 用于控制的次级微控制器
  - 〇 汽车音响
  - O AV 设备,家庭音响
  - O PC 外围设备 (键盘等)
  - 〇 家用电器
    - 空调设备
    - 微波炉, 电饭煲
  - 〇 工业设备
    - 水泵
    - 自动售货机
    - FA (工业自动化)

## ★1.3 定购信息

## • 闪存版本

| 产品型号                                  | 封装形式                   |
|---------------------------------------|------------------------|
| μPD78F0544GC(T)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0544GC(T2)-UBT-A                | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0544GC(S)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0544GC(R)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0544GK(T)-8EU-A                 | 80 引脚塑封 LQFP (12×12)   |
| μPD78F0544GK(T2)-8EU-A                | 80 引脚塑封 LQFP (12×12)   |
| μPD78F0544GK(S)-8EU-A                 | 80 引脚塑封 LQFP (12×12)   |
| μPD78F0544GK(R)-8EU-A                 | 80 引脚塑封 LQFP (12×12)   |
| μPD78F0545GC(T)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0545GC(T2)-UBT-A                | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0545GC(S)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0545GC(R)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0546GK(T)-8EU-A                 | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0546GK(T2)-8EU-A                | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0546GK(S)-8EU-A                 | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0546GK(R)-8EU-A                 | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0546GC(T)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0546GC(T2)-UBT-A                | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0546GC(S)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0546GC(R)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0546GK(T)-8EU-A                 | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0546GK(T2)-8EU-A                | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0546GK(S)-8EU-A                 | 80 引脚塑封 LQFP (12×12)   |
| μPD78F0546GK(R)-8EU-A                 | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0547GC(T)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0547GC(T2)-UBT-A                | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0547GC(S)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0547GC(R)-UBT-A                 | 80 引脚塑封 LQFP (14×14)   |
| μPD78F0547GK(T)-8EU-A                 | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0547GK(T2)-8EU-A                | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0547GK(S)-8EU-A                 | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0547GK(R)-8EU-A                 | 80 引脚塑封 LQFP (12 × 12) |
| μPD78F0547DGC(T)-UBT-A *              | 80 引脚塑封 LQFP (14 × 14) |
| μPD78F0547DGK(T)-8EU-A <sup>1</sup> * | 80 引脚塑封 LQFP (12 × 12) |
|                                       |                        |

**注:** μPD78F0547D 具有片上调试功能。大规模生产时不要使用本产品,因为在使用片上调试功能后,从闪存可重写的次数受到限制这一点来看,它的可靠性不能保证。NEC Electronics 不接受对于本产品的任何投诉。

## 备注 在产品型号末尾有-A 的是无铅产品。

按照生产过程将本产品的标准质量等级分类如下:

(T), (T2): 通用

(S): 单独合同

(R): 用于汽车附件

## 1.4 引脚配置(俯视图)

- 80 引脚塑封 LQFP (14 × 14)
- 80 引脚塑封 LQFP (12 × 12)



- ★ 注: 仅适用于 $\mu$ PD78F0547D(具有片上调试功能的产品)
- ★ 注意事项 1. 使 AVss 与 Vss 的电位相同。
  - 2. 通过一个电容(0.47μF: 目标)将 REGC 引脚和 Vss 连接到一起。
  - 3. 复位后, ANIO/P20 ~ ANI7/P27 设置为模拟输入模式。

#### 第一章 概述

## 引脚标识

ANIO ~ ANI7:模拟输入P120 ~ P124:端口 12AVREF:参考模拟电压P130:端口 13AVss:模拟地P140 ~ P145:端口 14

 BUSY0:
 串行忙输入
 PCL:
 可编程时钟输出

 BUZ:
 蜂鸣器输出
 REGC
 稳压器电容

 EVpp:
 端口电源
 RESET:
 复位

EVS: 编口电源 RESEI: 夏位 EVs: 端口地 RxD0, RxD6: 接收数据

 EXCLK:
 外部时钟输入
 SCK10, SCK11, SCKA0: 串行时钟输入/输出

 (主系统时钟)
 SCL0: 串行时钟输入/输出

 (主系统时钟)
 SCL0:
 串行时钟输入/输出

 EXCLKS:
 外部时钟输入
 SDA0:
 串行数据输入/输出

(子系统时钟)SI10, SI11, SIA0:串行数据输入EXLVI:外部电压输入SO10, SO11, SOA0:串行数据输出

用于低电压检测电路 SSI11: 串行接口芯片选择输入

EXSCL0: 外部串行时钟输入 STB0: 串口选通

FLMD0: 闪存编程模式 TI000, TI010, INTP0  $\sim$  INTP7: 外部中断输入 TI001, TI011,

KR0  $\sim$  KR7: 按键返回 TI50, TI51: 定时器输入

OCD0A, OCD0B, TO00, TO01, OCD1A, OCD1B: 片上调试输入/输出 TO50, TO51,

 $P00 \sim P06$ : 端口 0 TOH0, TOH1: 定时器输出 P10 ∼ P17: 端口 1 TxD0, TxD6: 发送数据 P20 ∼ P27: V<sub>DD</sub>: 供电电源 端口2  $P30 \sim P33$ : 端口3 Vss: 地

 P40 ~ P47:
 端口 4
 X1, X2:
 晶体振荡器(主系统时钟)

 P50 ~ P57:
 端口 5
 XT1, XT2:
 晶体振荡器(子系统时钟)

P60  $\sim$  P67: 端口 6 P70  $\sim$  P77: 端口 7

## 1.5 78K0/Kx2 系列介绍

| ROM    | RAM   | 78K0/KB2       | 78K0          | )/KC2         | 78K0/KD2             | 78K0/KE2             | 78K0/KF2             |
|--------|-------|----------------|---------------|---------------|----------------------|----------------------|----------------------|
|        |       | 30 引脚          | 44 引脚         | 48 引脚         | 52 引脚                | 64 引脚                | 80 引脚                |
| 128 KB | 7 KB  | -              | -             | -             | μPD78F0527D <b>*</b> | μPD78F0537D <b>*</b> | μPD78F0547D <b>*</b> |
|        |       |                |               |               | μPD78F0527           | μPD78F0537           | μPD78F0547           |
| 96 KB  | 5 KB  | -              | -             | -             | μPD78F0526           | μPD78F0536           | μPD78F0546           |
| 60 KB  | 3 KB  | -              | -             | μPD78F0515D** | μPD78F0525           | μPD78F0535           | μPD78F0545           |
|        |       |                |               | μPD78F0515    |                      |                      |                      |
| 48 KB  | 2 KB  | -              | -             | μPD78F0514    | μPD78F0524           | μPD78F0534           | μPD78F0544           |
| 32 KB  | 1 KB  | μPD78F0503D ** | μPD78F0513D** | μPD78F0513    | μPD78F0523           | μPD78F0533           | -                    |
|        |       | μPD78F0503     | μPD78F0513    |               |                      |                      |                      |
| 24 KB  | 1 KB  | μPD78F0502     | <i>μ</i> PD78 | 3F0512        | μPD78F0522           | μPD78F0532           | _                    |
| 16 KB  | 768 B | μPD78F0501     | <i>μ</i> PD78 | BF0511        | μPD78F0521           | μPD78F0531           | _                    |
| 8 KB   | 512 B | μPD78F0500     |               |               |                      |                      |                      |

注: 该产品具有片上调试功能

78K0/Kx2 功能列表如下。

(1/2)

|              |                        |                                                                                                                                                                               |                                                                                                                              |              |                       |            |           |           |            |            |        |      | (1/2) |
|--------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--------------|-----------------------|------------|-----------|-----------|------------|------------|--------|------|-------|
| _            | 产品型号                   |                                                                                                                                                                               | 78K0                                                                                                                         | /KB2         |                       |            |           |           | 78K0       | /KC2       |        |      |       |
| 项目           |                        |                                                                                                                                                                               | 30/36                                                                                                                        | 引脚           |                       |            | 44 引脚     |           |            |            | 48 引脚  |      |       |
| 闪存           | 字(KB)                  | 8                                                                                                                                                                             | 16                                                                                                                           | 24           | 32                    | 16         | 24        | 32        | 16         | 24         | 32     | 48   | 60    |
| RAI          | M (KB)                 | 0.5                                                                                                                                                                           | 0.75                                                                                                                         | 1            | 1                     | 0.75       | 1         | 1         | 0.75       | 1          | 1      | 2    | 3     |
| 组(           | (闪存)                   |                                                                                                                                                                               |                                                                                                                              |              |                       |            | -         | -         |            |            |        |      |       |
| 供申           | 电电压                    | V <sub>DD</sub> = 1.8 至 5.5 V                                                                                                                                                 |                                                                                                                              |              |                       |            |           |           |            |            |        |      |       |
| 稳归           | 压器                     |                                                                                                                                                                               |                                                                                                                              |              |                       |            | 提         | 供         |            |            |        |      |       |
| 指令           | 令最短执行时间                | 0.1 $\mu$ s (20 MHz: V <sub>DD</sub> = 4.0 $\cong$ 5.5 V)/0.2 $\mu$ s (10 MHz: V <sub>DD</sub> = 2.7 $\cong$ 5.5 V)/ 0.4 $\mu$ s (5 MHz: V <sub>DD</sub> = 1.8 $\cong$ 5.5 V) |                                                                                                                              |              |                       |            |           |           |            |            |        |      |       |
|              | 紫 本 高速系统时钟<br>内部高速振荡时钟 |                                                                                                                                                                               | 20 MHz: V <sub>DD</sub> = 4.0 $\Xi$ 5.5 V/10 MHz: V <sub>DD</sub> = 2.7 $\Xi$ 5.5 V/5 MHz: V <sub>DD</sub> = 1.8 $\Xi$ 5.5 V |              |                       |            |           |           |            |            |        |      |       |
| 时钟           | 内部高速振荡时钟               |                                                                                                                                                                               | 8 MHz (TYP.): V <sub>DD</sub> = 1.8 至 5.5 V                                                                                  |              |                       |            |           |           |            |            |        |      |       |
| 玉            | 子系统时钟                  |                                                                                                                                                                               | _ 32.768 kHz (TYP.): Vpd = 1.8 至 5.5 V                                                                                       |              |                       |            |           |           | V          |            |        |      |       |
|              | 内部低速振荡时钟               |                                                                                                                                                                               |                                                                                                                              |              |                       | 240 kHz    | (TYP.): \ | √dd = 1.8 | 3至 5.5 V   | 1          |        |      |       |
| П            | 合计                     |                                                                                                                                                                               | 2                                                                                                                            | 3            |                       |            | 37        |           |            |            | 41     |      |       |
| 辦            | N-ch O.D. (6 V 耐压)     |                                                                                                                                                                               | 2                                                                                                                            | 2            |                       |            | 4         |           |            |            | 4      |      |       |
|              | 16 位 (TM0)             |                                                                                                                                                                               |                                                                                                                              |              |                       |            | 1 追       | 通道        |            |            |        |      |       |
| 磐            | 8位(TM5)                |                                                                                                                                                                               |                                                                                                                              |              |                       |            | 2 追       | 通道        |            |            |        |      |       |
| 定时器          | 8位(TMH)                |                                                                                                                                                                               |                                                                                                                              |              |                       |            | 2 追       | 通道        |            |            |        |      |       |
| .fl-<        | 钟表                     |                                                                                                                                                                               |                                                                                                                              |              |                       |            |           |           |            |            |        |      |       |
|              | WDT                    |                                                                                                                                                                               |                                                                                                                              |              |                       |            | 1 近       | 通道        |            |            |        |      |       |
|              | 3线 CSI                 |                                                                                                                                                                               |                                                                                                                              | <del>-</del> |                       |            |           |           |            |            |        |      |       |
|              | 自动收发的 3 线 CSI          | <del>-</del>                                                                                                                                                                  |                                                                                                                              |              |                       |            |           |           |            |            |        |      |       |
| 串行接          | UART/3线 CSI **         | 1 通道                                                                                                                                                                          |                                                                                                                              |              |                       |            |           |           |            |            |        |      |       |
| ₩            | 支持 LIN 总线的 UART        |                                                                                                                                                                               | 1 通道                                                                                                                         |              |                       |            |           |           |            |            |        |      |       |
|              | I <sup>2</sup> C 总线    |                                                                                                                                                                               |                                                                                                                              |              |                       | 1          | 1 追       | <b>重道</b> |            |            |        |      |       |
| 10 4         | 位 A/D                  |                                                                                                                                                                               | 4 追                                                                                                                          | 通道           |                       |            |           |           | <b>1</b> 8 | <b>I</b> 道 |        |      |       |
| 中断           | 外部                     |                                                                                                                                                                               | (                                                                                                                            | 3            |                       |            | 7         |           |            |            | 8      |      |       |
| <del>-</del> | 内部                     |                                                                                                                                                                               | 1.                                                                                                                           | 4            |                       |            |           |           | 10         | 6          |        |      |       |
| 按領           | 建中断                    |                                                                                                                                                                               | -                                                                                                                            | =            |                       |            |           |           | 4 沪        | <b>重</b> 道 |        |      |       |
|              | RESET 引脚               |                                                                                                                                                                               |                                                                                                                              |              |                       |            | 提         | 供         |            |            |        |      |       |
| 复位           | POC                    |                                                                                                                                                                               |                                                                                                                              |              | 1.59 V ±              | 0.15 V (   | I.8 V 的」  | 上升时间:     | 3.6 ms     | (最大值))     | 1      |      |       |
| 赵            | LVI                    |                                                                                                                                                                               |                                                                                                                              |              |                       | 可选择        | 16 个供     | 电电压检      | 测级别        |            |        |      |       |
| WDT 提供       |                        |                                                                                                                                                                               |                                                                                                                              |              |                       |            |           |           |            |            |        |      |       |
| 时包           | 中输出/蜂鸣器输出              | - 仅有时钟输出                                                                                                                                                                      |                                                                                                                              |              |                       |            |           |           |            |            |        |      |       |
| 乘法           | 法器/除法器                 | -                                                                                                                                                                             |                                                                                                                              |              |                       |            |           | 提         | :供         |            |        |      |       |
| 片」           | 上调试功能                  | 17                                                                                                                                                                            | 又有μPD7                                                                                                                       | 8F0503I      | )                     | 仅有μ        | PD78F0    | 513D      |            | 仅有μ        | PD78F0 | 515D |       |
| 工化           | 作环境温度                  |                                                                                                                                                                               |                                                                                                                              | -40          | $\sim$ +85 $^{\circ}$ | C ((T), (F | k), (S) 产 | 品), -40   | ~ +125°    | C ((T2) 🖟  | 左品)    |      |       |

注: 选择这些复用功能引脚中的任意一种功能。

(2/2)

| T | _    | )                                           | (2/2)                                                 |                                                                                                                                                           |       |        |            |        |        |        |            |         |            |            |      |                   |          |       |    |     |
|---|------|---------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|------------|--------|--------|--------|------------|---------|------------|------------|------|-------------------|----------|-------|----|-----|
|   |      | 产品型号                                        |                                                       |                                                                                                                                                           |       | K0/KI  |            |        |        |        |            | 78      | 3K0/KI     | <b>E</b> 2 |      |                   | 78K0/KF2 |       |    |     |
|   | 项目   |                                             |                                                       |                                                                                                                                                           | 5     | 2 引服   | 却          | 1      |        |        |            | 6       | 64 引展      | ij.        | 1    |                   |          | 80 1  | 引脚 |     |
|   | 闪右   | F (KB)                                      | 16                                                    | 24                                                                                                                                                        | 32    | 48     | 60         | 96     | 128    | 16     | 24         | 32      | 48         | 60         | 96   | 128               | 48       | 60    | 96 | 128 |
|   |      | M (KB)                                      | 0.75                                                  | 1                                                                                                                                                         | 1     | 2      | 3          | 5      | 7      | 0.75   | 1          | 1       | 2          | 3          | 5    | 7                 | 2        | 3     | 5  | 7   |
|   |      | 闪存)                                         |                                                       |                                                                                                                                                           | _     |        |            | 4      | 6      |        |            | _       |            |            | 4    | 6                 | -        | _     | 4  | 6   |
|   |      | 1电压                                         |                                                       | V <sub>DD</sub> = 1.8 至 5.5 V                                                                                                                             |       |        |            |        |        |        |            |         |            |            |      |                   |          |       |    |     |
|   | 稳且   |                                             |                                                       | 提供                                                                                                                                                        |       |        |            |        |        |        |            |         |            |            |      |                   |          |       |    |     |
|   | 指令   | ·最短执行时间                                     |                                                       | $0.1~\mu s$ (20 MHz: $V_{DD}$ = $4.0~ \Xi$ $5.5~ V)/0.2~\mu s$ (10 MHz: $V_{DD}$ = $2.7~ \Xi$ $5.5~ V)/0.4~\mu s$ (5 MHz: $V_{DD}$ = $1.8~ \Xi$ $5.5~ V)$ |       |        |            |        |        |        |            |         |            |            |      |                   |          |       |    |     |
|   |      | 端 本     高速系统时钟       版 本     内部高速振荡时钟       |                                                       | 2                                                                                                                                                         | 20 MH | lz: Vd | D = 4.0    | 0至5    | .5 V/1 | 0 MHz  | z: Vdd     | = 2.7   | 至 5.5      | 5 V/5 I    | MHz: | V <sub>DD</sub> = | 1.8 至    | 5.5 \ | /  |     |
|   | 时钟   | 州 <sup> </sup>                              |                                                       |                                                                                                                                                           |       |        |            |        | 8 MF   | łz (TY | P.): V     | 'DD = 1 | .8至        | 5.5 V      |      |                   |          |       |    |     |
|   | 室    | 子系统时钟                                       |                                                       |                                                                                                                                                           |       |        |            | 3      | 2.768  | kHz (  | TYP.)      | : Vdd : | = 1.8      | 至 5.5      | ٧    |                   |          |       |    |     |
|   |      | 内部低速振荡时钟                                    |                                                       |                                                                                                                                                           |       |        |            |        | 240 k  | Hz (T  | YP.): \    | VDD =   | 1.8 至      | 5.5 V      | /    |                   |          |       |    |     |
| * | П    | 合计                                          |                                                       |                                                                                                                                                           |       | 45     |            |        |        | 55     |            |         |            |            |      | 7                 | 1        |       |    |     |
|   | 淵    | N-ch O.D. (6 V 耐压)                          |                                                       |                                                                                                                                                           |       | 4      |            |        |        |        |            |         | 4          |            |      |                   |          | 4     | 4  |     |
|   |      | 16 引脚 (TM0)                                 |                                                       |                                                                                                                                                           |       |        | <b>1</b> 近 | 通道     |        |        |            |         |            |            |      | 2 追               | 通道       |       |    |     |
|   | 器    | 8 引脚(TM5)                                   |                                                       |                                                                                                                                                           |       |        |            |        |        |        | <b>2</b> 迫 | 通道      |            |            |      |                   |          |       |    |     |
|   | 定时器  | 8 引脚(TMH)                                   |                                                       |                                                                                                                                                           |       |        |            |        |        |        | <b>2</b> 迫 | 通道      |            |            |      |                   |          |       |    |     |
|   | üΚ   | 钟表                                          |                                                       |                                                                                                                                                           |       |        |            |        |        |        | 1 迫        | 通道      |            |            |      |                   |          |       |    |     |
|   |      | WDT                                         |                                                       |                                                                                                                                                           |       |        |            |        |        |        | <b>1</b> 迫 | 通道      |            |            |      |                   |          |       |    |     |
|   |      | 3线 CSI                                      |                                                       | 1 <u>1</u> <u>1</u>                                                                                                                                       |       |        |            |        |        | 1 追    | <b></b> 道  |         |            |            |      |                   |          |       |    |     |
|   | ZK   | 自动收发的 3 线 CSI                               |                                                       | <del>-</del>                                                                                                                                              |       |        |            |        |        |        | 1 通道       |         |            |            |      |                   |          |       |    |     |
|   | 串行接1 | UART/3线 CSI **                              | 1 通道                                                  |                                                                                                                                                           |       |        |            |        |        |        |            |         |            |            |      |                   |          |       |    |     |
|   | ₩    | 支持 LIN 总线的 UART                             |                                                       |                                                                                                                                                           |       |        |            |        |        |        | <b>1</b> 迫 | 通道      |            |            |      |                   |          |       |    |     |
|   |      | I <sup>2</sup> C 总线                         |                                                       |                                                                                                                                                           |       |        |            |        |        |        |            | 通道      |            |            |      |                   |          |       |    |     |
|   | 10-  | 位 A/D                                       |                                                       |                                                                                                                                                           |       |        |            |        |        | T      | <b>8</b> 近 | 通道      |            |            |      |                   |          |       |    |     |
|   |      | 外部                                          |                                                       |                                                                                                                                                           |       | 8      |            |        |        |        |            |         | 1          |            | 9    |                   | 1        |       |    |     |
|   | 中断   | 内部                                          |                                                       |                                                                                                                                                           |       |        | 1          | 6      |        |        |            |         |            | 1          | 9    |                   |          | 2     | 0  |     |
|   | 按領   | 世中断<br>———————————————————————————————————— |                                                       |                                                                                                                                                           |       |        |            |        |        |        | <b>1</b> 8 | 通道      |            |            |      |                   |          |       |    |     |
|   |      | RESET 引脚                                    |                                                       |                                                                                                                                                           |       |        |            |        |        |        | 提          | 供       |            |            |      |                   |          |       |    |     |
| * | £位   | POC<br>I VI                                 |                                                       |                                                                                                                                                           |       |        | 1.5        | 59 V ± |        | V (1.8 |            |         |            |            | (最大( | 直))               |          |       |    |     |
|   | ₩,   | LVI                                         |                                                       |                                                                                                                                                           |       |        |            |        | 可进     | 择 16   | 个供         | 电电压     | <b>运检测</b> | 级别         |      |                   |          |       |    |     |
|   |      | WDT                                         |                                                       |                                                                                                                                                           |       |        |            |        |        |        | 提          | 供       |            |            |      |                   |          |       |    |     |
|   |      | 中输出/蜂鸣器输出                                   |                                                       |                                                                                                                                                           | 仅有    | f时钟:   |            |        |        | 提供     |            |         |            |            |      |                   |          |       |    |     |
|   |      | :器/除法器                                      |                                                       | -                                                                                                                                                         |       |        |            | 供      |        |        | -          |         |            |            |      | 提                 | 供        |       |    |     |
|   | 片上   | _调试功能                                       | 仅有μPD78F0527D                                         |                                                                                                                                                           |       |        |            |        |        | 47D    |            |         |            |            |      |                   |          |       |    |     |
| * | 工作   | 环境温度                                        | -40 ~+85°C ((T), (R), (S) 产品), -40 ~ +125°C ((T2) 产品) |                                                                                                                                                           |       |        |            |        |        |        |            |         |            |            |      |                   |          |       |    |     |

注: 选择这些复用功能引脚中的任意一种功能。

## 1.6 框图



**注 1:** 仅在 μPD78F0546, 78F0547, 和 78F0547D 中可用。

**注 2:** 仅在 μPD78F0547D 中可用

## 1.7 功能概述

(1/2)

|                 | 1舌口                     | DD7050547                                                                                                                                                               | DD7050545                        | DD7050546                        | DD7050545        | (1/2)       |  |  |  |  |  |
|-----------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------|------------------|-------------|--|--|--|--|--|
|                 | 项目                      | <i>µ</i> PD78F0544                                                                                                                                                      | <i>µ</i> PD78F0545               | <i>µ</i> PD78F0546               | μPD78F0547       | μPD78F0547D |  |  |  |  |  |
| 内部存储器           | 闪存(支持自编程) <sup>推1</sup> | 48 KB                                                                                                                                                                   | 60 KB                            | 96 KB                            | 128 KB           |             |  |  |  |  |  |
|                 | 存储器组 2                  | -                                                                                                                                                                       | -                                | 4 组                              | 6 组              |             |  |  |  |  |  |
|                 | 高速 RAM <sup>推 1</sup>   | 1 KB                                                                                                                                                                    |                                  |                                  |                  |             |  |  |  |  |  |
|                 | 扩展 RAM <sup>推1</sup>    | 1 KB                                                                                                                                                                    | 2 KB                             | 4 KB                             | 6 KB             |             |  |  |  |  |  |
|                 | 缓冲 RAM                  | 32 字节                                                                                                                                                                   |                                  |                                  |                  |             |  |  |  |  |  |
| 存储空间            | •                       | 64 KB                                                                                                                                                                   |                                  |                                  |                  |             |  |  |  |  |  |
| 主系统时钟<br>(振荡频率) | 高速系统时钟                  | , ,                                                                                                                                                                     | ,                                | 时钟输入(EXCLK)<br>~ 10 MHz: Vdd = 2 | $2.7\sim$ 5.5 V, |             |  |  |  |  |  |
|                 | 内部高速振荡时钟                | 内部振荡器<br>8 MHz (TYP.): V <sub>DD</sub> = 1.8 ~ 5.5 V                                                                                                                    |                                  |                                  |                  |             |  |  |  |  |  |
| 子系统时钟<br>(振荡频率) |                         | , , , , , , , ,                                                                                                                                                         | 片,外部子系统时钟<br>P.): Vɒɒ = 1.8 ~ 5. | ,                                |                  |             |  |  |  |  |  |
| 内部低速振荡<br>WDT)  | 所钟(用于 TMH1,             | 内部振荡器 240 kHz (TYP.): $V_{DD}$ = 1.8 $\sim$ 5.5 $V$                                                                                                                     |                                  |                                  |                  |             |  |  |  |  |  |
| 通用寄存器           |                         | 8 位 × 32 个寄存器                                                                                                                                                           | 器 (8 位 × 8 个寄存器                  | 路×4组)                            |                  |             |  |  |  |  |  |
| 指令最短执行          | 时间                      | 0.1 µs (高速系统时钟: @ fxH = 20 MHz 操作)                                                                                                                                      |                                  |                                  |                  |             |  |  |  |  |  |
|                 |                         | 0.25 μs (内部高速振荡时钟: @ frн = 8 MHz (TYP.) 操作)                                                                                                                             |                                  |                                  |                  |             |  |  |  |  |  |
|                 |                         | 122 μs (子系统时钟: @ fsuв = 32.768 kHz 操作)                                                                                                                                  |                                  |                                  |                  |             |  |  |  |  |  |
| 指令集             |                         | <ul> <li>8 位操作, 16 位操作</li> <li>乘/除(8 位 × 8 位, 16 位 ÷ 8 位)</li> <li>位操作(置位, 复位, 测试和布尔操作)</li> <li>BCD 调整等。</li> </ul>                                                   |                                  |                                  |                  |             |  |  |  |  |  |
| I/O 端口          |                         | 合计:                                                                                                                                                                     | 71                               |                                  |                  |             |  |  |  |  |  |
|                 |                         | CMOS I/O:                                                                                                                                                               | 66                               |                                  |                  |             |  |  |  |  |  |
|                 |                         | CMOS 输出:                                                                                                                                                                | 1                                |                                  |                  |             |  |  |  |  |  |
| 定时器             |                         | N-ch 漏极开路 I/O (6 V 耐压): 4  • 16 位定时器/事件计数器: 2 通道 • 8 位定时器/事件计数器: 2 通道 • 8 位定时器: 2 通道 • 钟表定时器: 1 通道 • 看门狗定时器: 1 通道                                                       |                                  |                                  |                  |             |  |  |  |  |  |
|                 | 定时器输出                   | 6 (PWM 输出: 4, PPG 输出: 2)                                                                                                                                                |                                  |                                  |                  |             |  |  |  |  |  |
| 输出时钟            |                         | <ul> <li>156.25 kHz, 312.5 kHz, 625 kHz, 1.25 MHz, 2.5 MHz, 5 MHz, 10 MHz (外围设备硬件时钟: @ fprs = 20 MHz 操作)</li> <li>32.768 kHz (子系统时钟: @ fsub = 32.768 kHz 操作)</li> </ul> |                                  |                                  |                  |             |  |  |  |  |  |
| 蜂鸣器输出           |                         | 2.44 kHz, 4.88 kHz, 9.77 kHz, 19.54 kHz<br>(外围设备硬件时钟: @ fprs = 20 MHz 操作)                                                                                               |                                  |                                  |                  |             |  |  |  |  |  |
| A/D 转换器         |                         | 10 位分辨率× 8 通道(AV <sub>REF</sub> = 2.3 ~ 5.5 V))                                                                                                                         |                                  |                                  |                  |             |  |  |  |  |  |

- 注: 1. 通过使用内存容量切换寄存器(IMS)和内部扩展 RAM 容量切换寄存器(IXS),可以改变内部闪存,内部高速 RAM 容量和内部扩展 RAM 的容量。
  - 2. 通过使用存储器组选择寄存器(BANK)可以改变要使用的存储器组。

(2/2)

|         |        |                                                                                                                     |                                       |                    |                                      | (2/2)               |
|---------|--------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------|--------------------|--------------------------------------|---------------------|
|         | 项目     | <i>µ</i> PD78F0544                                                                                                  | <i>µ</i> PD78F0545                    | <i>µ</i> PD78F0546 | μPD78F0547                           | <i>µ</i> PD78F0547D |
| 串行接口    |        | <ul> <li>支持 LIN 总线的</li> <li>3线串行 I/O/UA</li> <li>3线串行 I/O:</li> <li>具有自动收发功</li> <li>I<sup>2</sup>C 总线:</li> </ul> |                                       | ·<br>注文:           | 1 通道<br>1 通道<br>1 通道<br>1 通道<br>1 通道 |                     |
| 乘法器/除法器 | 1 12/2 |                                                                                                                     |                                       |                    |                                      |                     |
| 向量中断源   | 内部     | 20                                                                                                                  |                                       |                    |                                      |                     |
|         | 外部     | 9                                                                                                                   |                                       |                    |                                      |                     |
| 按键中断    |        | 通过检测按键输入                                                                                                            | 引脚(KR0 ~ KR7)的                        | 的下降沿,产生按键          | 津中断 (INTKR)。                         |                     |
| 复位      |        | <ul><li>使用 RESET 引</li><li>用看门狗定时器</li><li>用 POC 进行内部</li><li>用低电压检测电</li></ul>                                     | 进行内部复位<br>邻复位                         |                    |                                      |                     |
| 片上调试功能  |        | 无                                                                                                                   |                                       |                    |                                      | 提供                  |
| 供电电压    |        | $V_{DD}$ = 1.8 $\sim$ 5.5 $V$                                                                                       |                                       |                    |                                      |                     |
| 工作环境温度  |        | <ul> <li>T<sub>A</sub> = -40 ~ +85</li> <li>T<sub>A</sub> = -40 ~ +12</li> </ul>                                    | °C ((T), (R), (S) 产。<br>5°C ((T2) 产品) | 品)                 |                                      |                     |
| 封装形式    |        | • 80 引脚塑封 LQi<br>• 80 引脚塑封 LQi                                                                                      |                                       |                    |                                      |                     |

注: 选择这些复用功能引脚中的任意一种功能。

## ★ 定时器概要说明

|     |         | 16 位复<br>事件计数<br>0 | (器 00 和 | 8 位定<br>事件计数器 | 医时器/<br>器 50 和 51 | 8 位计数器 | ₹ H0 和 H1          | 钟表<br>定时器          | 看门狗<br>定时器 |
|-----|---------|--------------------|---------|---------------|-------------------|--------|--------------------|--------------------|------------|
|     |         | TM00               | TM01    | TM50          | TM51              | TMH0   | TMH1               |                    |            |
| 功能  | 间隔定时器   | 1 通道               | 1 通道    | 1 通道          | 1 通道              | 1 通道   | 1 通道               | 1 通道 <sup>推1</sup> | _          |
|     | 外部事件计数器 | 1 通道               | 1 通道    | 1 通道          | 1 通道              | -      | -                  | -                  | -          |
|     | PPG 输出  | 1 输出               | 1 输出    | -             | _                 | _      | -                  | _                  | -          |
|     | PWM 输出  | -                  | -       | 1 输出          | 1 输出              | 1 输出   | 1 输出               | -                  | -          |
|     | 脉冲宽度测量  | 2 输入               | 2 输入    | -             | _                 | _      | -                  | _                  | -          |
|     | 方波输出    | 1 输出               | 1 输出    | 1 输出          | 1 输出              | 1 输出   | 1 输出               | _                  | -          |
|     | 载波发生器   | =                  | =       | =             | =                 | -      | 1 输出 <sup>推2</sup> | =                  | =          |
|     | 定时器输出   | -                  | -       | -             | -                 | -      | -                  | 1 通道 <sup>推1</sup> | -          |
|     | 看门狗定时器  | -                  | -       | -             | -                 | -      | -                  | -                  | 1 通道       |
| 中断源 |         | 2                  | 2       | 1             | 1                 | 1      | 1                  | 1                  | _          |

注1: 看门狗定时器功能和间隔定时器功能可同时使用。

注 2: TM51 和 TMH1 可联合使用,作为载波发生器模式。

## 第二章 引脚功能

## 2.1 引脚功能列表

有三种类型的引脚 I/O 缓冲式供电电源: AVREF、EVDD 和 VDD。下表显示了这些供电电源与引脚之间的关系。

\*

表 2-1 引脚 I/O 缓冲式供电电源

| 供电电源             | 对应的引脚                                            |
|------------------|--------------------------------------------------|
| AVREF            | P20 至 P27                                        |
| EV <sub>DD</sub> | 端口引脚(P20 ~ P27 和 P121 ~ P124 除外)                 |
| V <sub>DD</sub>  | <ul><li>P121 ~ P124</li><li>引脚(端口引脚除外)</li></ul> |

## (1) 引脚功能 (1/2)

| 功能名称      | I/O | 功能                                    | 复位后  | 复用功能            |
|-----------|-----|---------------------------------------|------|-----------------|
| P00       | I/O | 端口 0。                                 | 输入端口 | TI000           |
| P01       |     | 7位 I/O 端口。                            |      | TI010/TO00      |
| P02       |     | 可以位选输入/输出模式。<br>通过软件设置,可以定义内置上拉电阻的使用。 |      | SO11            |
| P03       |     |                                       |      | SI11            |
| P04       |     |                                       |      | SCK11           |
| P05       |     |                                       |      | TI001/SSI11     |
| P06       |     |                                       |      | TI011/TO01      |
| P10       | I/O | 端口 1。                                 | 输入端口 | SCK10/TxD0      |
| P11       |     | 8位 I/O 端口。                            |      | SI10/RxD0       |
| P12       |     | 可以位选输入/输出模式。<br>通过软件设置,可以定义内置上拉电阻的使用。 |      | SO10            |
| P13       |     |                                       |      | TxD6            |
| P14       |     |                                       |      | RxD6            |
| P15       |     |                                       |      | ТОН0            |
| P16       |     |                                       |      | TOH1/INTP5      |
| P17       |     |                                       |      | TI50/TO50       |
| P20 ∼ P27 | I/O | 端口 2。<br>8 位 I/O 端口。<br>可以位选输入/输出模式。  | 模拟输入 | ANIO ~ ANI7     |
| P30       | I/O | 端口 3。                                 | 输入端口 | INTP1           |
| P31       |     | 4 位 I/O 端口。<br>可以位选输入/输出模式。           |      | INTP2/OCD1A **  |
| P32       |     | 通过软件设置,可以定义内置上拉电阻的使用。                 |      | INTP3/OCD1B **  |
| P33       |     |                                       |      | TI51/TO51/INTP4 |

## ★ 注: 仅用于µPD78F0547D

## (1) 端口功能 (2/2)

| 功能名称      | I/O | 功能                                                            | 复位后  | 复用功能                  |
|-----------|-----|---------------------------------------------------------------|------|-----------------------|
| P40 ~ P47 | I/O | 端口 4。 8 位 I/O 端口。 可以位选输入/输出模式。 通过软件设置,可以定义内置上拉电阻的使用。          | 输入端口 | -                     |
| P50 ~ P57 | I/O | 端口 5。<br>8 位 I/O 端口。<br>可以位选输入/输出模式。<br>通过软件设置,可以定义内置上拉电阻的使用。 | 输入端口 | _                     |
| P60       | I/O | 端口 6。                                                         | 输入端口 | SCL0                  |
| P61       |     | 8 位 I/O 端口。<br>P60 ~ P63 输出是 N-ch 漏极开路输出(6V 耐压).              |      | SDA0                  |
| P62       |     | 可以位选输入/输出模式。                                                  |      | EXSCL0                |
| P63 ~ P67 |     | 仅对于 $P64 \sim P67$ , 通过软件设置,可以定义内置上拉电阻的 使用。                   |      | -                     |
| P70 ~ P77 | I/O | 端口 7。<br>8 位 I/O 端口。<br>可以位选输入/输出模式。<br>通过软件设置,可以定义内置上拉电阻的使用。 | 输入端口 | KR0 ∼ KR7             |
| P120      | I/O | 端口 12。                                                        | 输入端口 | INTP0/EXLVI           |
| P121      |     | 5位 I/O 端口。                                                    |      | X1/OCD0A <sup>≇</sup> |
| P122      |     | 可以位选输入/输出模式。<br>仅对于 P120,通过软件设置,可以定义内置上拉电阻的使用。                |      | X2/EXCLK/OCD0B **     |
| P123      |     | [X/3] F120,题是抓住权且,周以及关约且上担电阻的使用。                              |      | XT1                   |
| P124      |     |                                                               |      | XT2/EXCLKS            |
| P130      | 输出  | 端口 <b>13</b> 。<br><b>1</b> 位仅输出端口。                            | 输出端口 | _                     |
| P140      | I/O | 端口 14。                                                        | 输入端口 | PCL/INTP6             |
| P141      |     | 6 位 I/O 端口。<br>可以位选输入/输出模式。                                   |      | BUZ/BUSY0/INTP7       |
| P142      |     | 通过软件设置,可以定义内置上拉电阻的使用。                                         |      | SCKA0                 |
| P143      |     |                                                               |      | SIA0                  |
| P144      |     |                                                               |      | SOA0                  |
| P145      | ]   |                                                               |      | STB0                  |

## ★ 注: 仅用于μPD78F0547D

## (2) 非端口功能 (1/2)

| 功能名称                     | I/O | 功能                                                          | 复位后  | 复用功能             |
|--------------------------|-----|-------------------------------------------------------------|------|------------------|
| ANIO $\sim$ ANI7         | 输入  | A/D 转换器模拟输入                                                 | 模拟输入 | P20 ∼ P27        |
| BUSY0                    | 输入  | CSIA0 忙输入                                                   | 输入端口 | P141/BUZ/INTP7   |
| BUZ                      | 输出  | 蜂鸣器输出                                                       | 输入端口 | P141/BUSY0/INTP7 |
| EXLVI                    | 输入  | 用于外部低电压检测的电压输入                                              | 输入端口 | P120/INTP0       |
| EXSCL0                   | 输入  | 用于 I <sup>2</sup> C 的外部时钟输入<br>为输入外部时钟,输入一个 6.4 MHz 的时钟。    | 输入端口 | P62              |
| FLMD0                    | =   | 闪存编程模式设置                                                    | =    | -                |
| INTP0                    | 输入  | 定义有效沿(上升沿、下降沿,或兼有上升沿和下降沿),<br>用于外部中断请求输入                    | 输入端口 | P120/EXLVI       |
| INTP1                    |     |                                                             |      | P30              |
| INTP2                    |     |                                                             |      | P31/OCD1A **     |
| INTP3                    |     |                                                             |      | P32/OCD1B **     |
| INTP4                    |     |                                                             |      | P33/TI51/TO51    |
| INTP5                    |     |                                                             |      | P16/TOH1         |
| INTP6                    |     |                                                             |      | P140/PCL         |
| INTP7                    |     |                                                             |      | P141/BUZ/BUSY0   |
| ${\rm KR0}\sim{\rm KR7}$ | 输入  | 按键中断输入                                                      | 输入端口 | P70 to P77       |
| PCL                      | 输出  | 时钟输出(用于高速系统时钟、子系统时钟的调整)                                     | 输入端口 | P140/INTP6       |
| REGC                     | -   | 将稳压器输出(2.5V)连接至稳定电容,用于内部操作。<br>通过一个电容器(0.47 μF: 目标)连接至 Vss。 | -    | _                |
| RESET                    | 输入  | 系统复位输入                                                      | -    | -                |
| RxD0                     | 输入  | UARTO 的串行数据输入                                               | 输入端口 | P11/SI10         |
| RxD6                     | 输入  | UART6 的串行数据输入                                               | 输入端口 | P14              |
| SCK10                    | I/O | CSI10,CSI11 的时钟输入/输出                                        | 输入端口 | P10/TxD0         |
| SCK11                    |     |                                                             |      | P04              |
| SCKA0                    | I/O | CSIA0 的时钟输入/输出                                              | 输入端口 | P142             |
| SCL0                     | I/O | I <sup>2</sup> C 的时钟输入/输出                                   | 输入端口 | P60              |
| SDA0                     | I/O | I <sup>2</sup> C 的串行数据 I/O                                  | 输入端口 | P61              |
| SI10                     | 输入  | CSI10,CSI11 的串行数据输入                                         | 输入端口 | P11/RxD0         |
| SI11                     |     |                                                             |      | P03              |
| SIA0                     | 输入  | CSIA0 的串行数据输入                                               | 输入端口 | P143             |
| SO10                     | 输出  | CSI10,CSI11 的串行数据输出                                         | 输入端口 | P12              |
| SO11                     |     |                                                             |      | P02              |
| SOA0                     | 输出  | CSIA0 的串行数据输出                                               | 输入端口 | P144             |
| SSI11                    | 输入  | CSI11 的芯片选择输入                                               | 输入端口 | P05/TI001        |
| STB0                     | 输出  | CSIA0 的选通输出                                                 | 输入端口 | P145             |

## ★ 注: 仅用于μPD78F0547D

## (2) 非端口功能(2/2)

| 功能名称               | I/O | 功能                                                                      | 复位后  | 复用功能                          |
|--------------------|-----|-------------------------------------------------------------------------|------|-------------------------------|
| T1000              | 输入  | 16 位定时器/事件计数器 00 的外部计数时钟输入 16 位定时器/事件计数器 00 的捕捉寄存器(CR000、CR010) 的捕捉触发输入 | 输入端口 | P00                           |
| TI001              |     | 16 位定时器/事件计数器 01 的外部计数时钟输入 16 位定时器/事件计数器 01 的捕捉寄存器(CR001、CR011) 的捕捉触发输入 |      | P05/SSI11                     |
| TI010              | 输入  | 16 位定时器/事件计数器 00 的捕捉寄存器(CR000)的捕捉触 发输入                                  | 输入端口 | P01/TO00                      |
| TI011              |     | 16 位定时器/事件计数器 01 的捕捉寄存器(CR001)的捕捉触 发输入                                  |      | P06/TO01                      |
| TI50               | 输入  | 8位定时器/事件计数器 50 的外部计数时钟输入                                                | 输入端口 | P17/TO50                      |
| TI51               |     | 8 位定时器/事件计数器 51 的外部计数时钟输入                                               |      | P33/TO51/INTP4                |
| TO00               | 输出  | 16 位定时器/事件计数器 00 输出                                                     | 输入端口 | P01/Tl010                     |
| TO01               |     | 16 位定时器/事件计数器 01 输出                                                     |      | P06/TI011                     |
| TO50               | 输出  | 8 位定时器/事件计数器 50 输出                                                      | 输入端口 | P17/TI50                      |
| TO51               |     | 8 位定时器/事件计数器 51 输出                                                      |      | P33/TI51/INTP4                |
| TOH0               | 输出  | 8 位定时器 H0 输出                                                            | 输入端口 | P15                           |
| ТОН1               |     | 8 位定时器 H1 输出                                                            |      | P16/INTP5                     |
| TxD0               | 输出  | 从 UARTO 输出串行数据                                                          | 输入端口 | P10/SCK10                     |
| TxD6               | 输出  | 从 UART6 输出串行数据                                                          | 输入端口 | P13                           |
| X1                 | =   | 连接主系统时钟振荡器                                                              | 输入端口 | P121/OCD0A **                 |
| X2                 | _   |                                                                         | 输入端口 | P122/EXCLK/OCD0B <sup>≇</sup> |
| EXCLK              | 输入  | 主系统时钟的外部时钟输入                                                            | 输入端口 | P122/X2/OCD0B **              |
| XT1                | _   | 连接子系统时钟振荡器                                                              | 输入端口 | P123                          |
| XT2                | _   |                                                                         | 输入端口 | P124/EXCLKS                   |
| EXCLKS             | 输入  | 子系统时钟的外部时钟输入                                                            | 输入端口 | P124/XT2                      |
| V <sub>DD</sub>    | ı   | 正向供电电源(P121 ~ P124 和端口除外)                                               | _    | -                             |
| EV <sub>DD</sub>   | _   | 端口的正向供电电源(P20~ P27 和 P121 ~ P124 除外)                                    | _    | -                             |
| AVREF              | _   | A/D 转换器的参考电压输入和 P20 ~ P27 及 A/D 转换器的正向供电电源                              | _    | -                             |
| Vss                | -   | 地电位(P121 ~ P124 和端口除外)                                                  | -    | -                             |
| EVss               | -   | 端口地电位(P20 ~ P27 和 P121 ~ P124 除外)                                       | =    | _                             |
| AVss               | -   | A/D 转换器的地电位。应与 EVss 或 Vss的电位相同                                          | -    | -                             |
| OCD0A **           | 输入  | 用于设置片上调试模式(仅用于 <i>μ</i> PD78F0547D)                                     | 输入端口 | P121/X1                       |
| OCD1A <sup>≇</sup> |     |                                                                         |      | P31/INTP2                     |
| OCD0B <sup>≇</sup> | _   | ]                                                                       |      | P122/X2/EXCLK                 |
| OCD1B <sup>#</sup> |     |                                                                         |      | P32/INTP3                     |

## ★ 注: 仅用于µPD78F0547D

## 2.2 引脚功能描述

## 2.2.1 P00至P06 (端口 0)

P00 至 P06 作为 7 位 I/O 端口使用。 这些引脚也可用于定时器 I/O、串行接口数据 I/O、时钟 I/O 以及芯片选择输入。

以下操作模式可以用位操作。

## (1) 端口模式

P00 至 P06 作为 7 位 I/O 端口使用。通过使用端口模式寄存器 0 (PM0),可按位设置 P00 至 P06 为输入输出端口。由上拉电阻选择寄存器 0 (PU0)规定内置上拉电阻的使用。

#### (2) 控制模式

P00至 P06 可用于定时器 I/O、串行接口数据 I/O、时钟 I/O 以及芯片选择输入。

#### (a) TI000 TI001

将外部计数时钟输入到 16 位定时器/事件计数器 00 和 01,也可将捕捉触发信号输入到 16 位定时器/事件计数器 00 和 01 的捕捉寄存器(CR000、CR010 或 CR001、CR011)中。

## (b) TI010 \ TI011

将捕捉触发信号输入到 16 位定时器/事件计数器 00 和 01 的捕捉寄存器(CR000 或 CR001)中。

#### (c) TO00, TO01

用于 16 位定时器/时间计数器 00 和 01 的定时器输出。

## (d) SI11

用于串行接口 CSI11 的串行数据输入。

## (e) SO11

用于串行接口 CSI11 的串行数据输出。

## (f) SCK11

用于串行接口 CSI11 的串行时钟 I/O。

## (g) SSI11

用于串行接口 CSI11 的芯片选择输入。

## 2.2.2 P10 至 P17 (端口 1)

P10至 P17作为 8位 I/O端口使用。这些引脚也可用于外部中断请求输入、串行接口数据 I/O、时钟 I/O 以及定时器 I/O。

以下操作模式可以用位操作。

## (1) 端口模式

P10 至 P17 作为 8 位 I/O 端口使用。通过使用端口模式寄存器 1 (PM1),可按位设置 P10 至 P17 为输入输出端口。由上拉电阻选择寄存器 1 (PU1)定义内置上拉电阻的使用。

## (2) 控制模式

P10 至 P17 可用于外部中断请求输入、串行接口数据 I/O、时钟 I/O 和定时器 I/O。

#### (a) SI10

用于串行接口 CSI10 的串行数据输入。

## (b) SO10

用于串行接口 CSI10 的串行数据输出。

## (c) SCK10

用于串行接口 CSI10 的串行时钟 I/O。

#### (d) RxD0

用于串行接口 UARTO 的串行数据输入。

## (e) RxD6

用于串行接口 UART6 的串行数据输入。

#### (f) TxD0

用于串行接口 UARTO 的串行数据输出。

#### (g) TxD6

用于串行接口 UART6 的串行数据输出。

## (h) TI50

用于输入一个外部计数时钟到8位定时器/事件计数器50。

## (i) TO50

用于8位定时器/事件计数器50的定时器输出。

## (j) TOH0、TOH1

用于 8 位定时器 H0 和 H1 的定时器输出。

## (k) INTP5

可定义有效沿(上升沿、下降沿,或兼有上升沿和下降沿),用于外部中断请求输入。

## 2.2.3 P20至 P27 (端口 2)

P20 至 P27 作为 8 位 I/O 端口使用,也可用于 A/D 转换器模拟输入。以下操作模式可以用位操作。

## (1) 端口模式

P20 至 P27 作为 8 位 I/O 端口使用。通过使用端口模式寄存器 2 (PM2),可按位设置 P20 至 P27 为输入输出端口。

## (2) 控制模式

P20 至 P27 用于 A/D 转换器模拟输入引脚(ANIO 至 ANI7),可参见 **13.6 A/D 转换器注意事项**中**(5) ANIO/P20 至** ANI7/P27

注意事项: 复位后, ANIO/P20 至 ANI7/P27 被设置为模拟输入模式。

#### 2.2.4 P30 至 P33 (端口 3)

P30 至 P33 作为 4 位 I/O 端口使用,也可用于外部中断请求输入和定时器 I/O。 以下操作模式可以用位操作。

## (1) 端口模式

P30 至 P33 作为 4 位 I/O 端口使用。 通过使用端口模式寄存器 3 (PM3),可按位设置 P30 至 P33 为输入输出端口。由上拉电阻选择寄存器 3 (PU3)定义内置上拉电阻的使用。

## (2) 控制模式

P30至 P33 用于外部中断请求输入和定时器 I/O。

#### (a) INTP1 至 INTP4

可定义有效沿(上升沿、下降沿,或兼有上升沿和下降沿),用于外部中断请求输入。

## (b) TI51

将外部计数时钟输入到8位定时器/事件计数器51中。

## (c) TO51

用于8位定时器/事件计数器51的定时器输出。

注意事项: 在µPD78F0547D 中,复位前必须下拉 P31,以避免误操作。

**备注:** 仅在μPD78F0547D 中,当使用片上调试功能时,P31 和 P32 可用作片上调试模式设置引脚 (OCD1A、 OCD1B)。关于如何连接支持片上调试的在线仿真器(QB-78K0MINI),可参见**第二十八章 片上调试功能(仅用于μPD78F0547D)**。

## 2.2.5 P40至P47 (端口 4)

P40 至 P47 作为 8 位 I/O 端口使用。通过使用端口模式寄存器 4 (PM4),可按位设置 P40 至 P47 为输入输出端口。由上拉电阻选择寄存器 4 (PU4)定义内置上拉电阻的使用。

## 2.2.6 P50至P57 (端口5)

P50 至 P57 作为 8 位 I/O 端口使用。通过使用端口模式寄存器 5 (PM5),可按位设置 P50 至 P57 为输入输出端口。由上拉电阻选择寄存器 5 (PU5)定义内置上拉电阻的使用。

#### 2.2.7 P60 至 P67 (端口 6)

P60 至 P67 作为 8 位 I/O 端口使用,也可作为串行接口数据 I/O、时钟 I/O 和外部时钟输入引脚。以下操作模式可以用位操作。

#### (1) 端口模式

P60 至 P67 作为 8 位 I/O 端口使用。通过使用端口模式寄存器 6 (PM6),可按位设置 P60 至 P67 为输入输出端口。仅对于 P64 至 P67,由上拉电阻选择寄存器 6 (PU6)定义内置上拉电阻的使用。

P60 至 P63 输出为 N-ch 漏极开路输出(6 V 耐压)。

## (2) 控制模式

P60 至 P67 作为串行接口数据 I/O, 时钟 I/O 和外部时钟输入使用。

#### (a) SDA0

用于串行接口 IIC0 的串行数据 I/O。

#### (b) SCL0

用于串行接口 IIC0 的串行时钟 I/O。

## (c) EXSCL0

将外部时钟输入到串行接口 IIC0 中。为输入外部时钟,需输入一个频率为 6.4MHz 的时钟。

#### 2.2.8 P70 至 P77 (端口 7)

P70至 P77作为8位 I/O 端口使用,也可用于按键中断输入。以下操作模式可以用位操作。

## (1) 端口模式

P70 至 P77 作为 8 位 I/O 端口使用。通过使用端口模式寄存器 7(PM7),可按位设置 P70 至 P77 为输入输出端口。由上拉电阻选择寄存器 7(PU7)定义内置上拉电阻的使用。

## (2) 控制模式

P70至 P77 用于按键中断输入。

#### (a) KR0 至 KR7

用于按键中断输入。

## 2.2.9 P120 至 P124 (端口 12)

P120 至 P124 作为 5 位 I/O 端口使用,也可以作为外部中断请求输入、外部低电压检测的电压输入、连接主系统时钟振荡器、连接子系统时钟振荡器、主系统时钟的外部时钟输入和子系统时钟的外部时钟输入。以下操作模式可以用位操作。

#### (1) 端口模式

P120 至 P124 作为 5 位 I/O 端口使用,可由端口模式寄存器 12(PM12),将 P120 至 P124 设置为输入或输出端口。仅 P120,可由上拉电阻选择寄存器 12(PU12)定义内置上拉电阻的使用。

## (2) 控制模式

P120 至 P124 可作为外部中断请求输入、外部低电压检测的电压输入、连接主系统时钟的振荡器、连接子系统时钟的振荡器、主系统时钟的外部时钟输入和子系统时钟的外部时钟输入使用。

## (a) INTP0

通过定义有效沿(上升沿、下降沿,或兼有上升沿和下降沿),它可作为外部中断请求输入(INTPO)使用。

## (b) EXLVI

用于外部低电压检测的电压输入。

## (c) X1, X2

用于连接主系统时钟振荡器。

## (d) EXCLK

用于主系统时钟的外部时钟输入。

#### (e) XT1, XT2

用于连接子系统时钟振荡器。

## (f) EXCLKS

用于子系统时钟的外部时钟输入。

**备注:** 仅在μPD78F0547D 中,当使用片上调试功能时,X1 和 X2 可用作片上调试模式设置引脚 (OCD0A、 OCD0B)。关于如何连接支持片上调试的在线仿真器(QB-78K0MINI),可参见**第二十八章 片上调试功能(仅用于μPD78F0547D)**。

## 2.2.10 P130 (端口13)

P130作为1位仅输出端口使用。

**备注:** 当设备复位后,P130 输出一个低电平。因此,在设备复位前使 P130 输出高电平,P130 的输出信号可用作虚拟的 CPU 复位信号(参见 **5.2.10 端口 13 备注**中的图)。

### 2.2.11 P140 至 P145 (端口 14)

P140 至 P145 作为 6 位 I/O 端口使用,也可用于外部中断请求输入、时钟输出、蜂鸣器输出、串行接口数据 I/O、时钟 I/O、忙输入以及选通输出。

以下操作模式可以用位操作。

#### (1) 端口模式

P140 至 P145 作为 6 位 I/O 端口使用。 通过使用端口模式寄存器 14(PM14),可按位设置 P140 至 P145 为输入输出端口。由上拉电阻选项寄存器 14(PU14),可定义内置上拉电阻的使用。

### (2) 控制模式

P140 至 P145 用于外部中断请求输入、时钟输出、蜂鸣器输出、串行接口数据 I/O、时钟 I/O、忙输入以及选通输出。

## (a) INTP6、INTP7

通过定义有效沿(上升沿、下降沿,或兼有上升沿和下降沿),可用于外部中断请求输入。

### (b) PCL

用于时钟输出。

### (c) BUZ

用于蜂鸣器输出。

### (d) BUSY0

用于串行接口 CSIA0 忙输入。

#### (e) SIA0

用于串行接口 CSIAO 串行数据输入。

### (f) SOA0

用于串行接口 CSIAO 串行数据输出。

#### (g) SCKA0

用于串行接口 CSIA0 串行时钟 I/O。

#### (h) STB0

用于串行接口 CSIAO 选通输出。

### 2.2.12 AVREF

用于 A/D 转换器参考电压输入和 P20 至 P27 及 A/D 转换器的正向电源供电。 不使用 A/D 转换器时,将该引脚直接连到 EVpp或 Vpp<sup>键</sup>。

注: 当端口 2 作为数字端口使用时,应使 AVREF 引脚电平与 VDD 引脚的电平相同。

### 2.2.13 AVss

作为 A/D 转换器的地引脚。即使在不使用 A/D 转换器时,该引脚电平也始终应与 Vss 相同。

### 2.2.14 **RESET**

用于系统复位输入。

### 2.2.15 REGC

用于内部操作的稳压器输出(2.5 V)稳定电容的连接。通过一个电容(0.47 μF: 目标)将此引脚连接到 Vss。



★ 注意事项:在上图虚线部分,用尽可能短的配线连接。

### ★ 2.2.16 V<sub>DD</sub> and EV<sub>DD</sub>

Voo 为正向供电电源引脚(P121 至 P124 与端口除外)。 EVoo 为端口的正向供电电源引脚(P20 至 P27 与 P121 至 P124 除外)。

### ★ 2.2.17 Vss 和 EVss

Vss 为地引脚(端口和 P121 至 P124 除外)。

EVss 为端口的地引脚(P20 至 P27 和 P121 至 P124 除外)。

### 2.2.18 FLMD0

用于闪存编程模式设置。

在正常操作模式下将 FLMD0 连接至 EVss 或 Vss。

在闪存编程模式下,将该引脚连接至闪存编程器。

# 2.3 引脚 I/O 电路和未使用引脚的建议连接方式

表 2-2 为引脚 I/O 电路类型和未使用引脚的建议连接方式。 参考**图 2-1**:显示每一种类型的 I/O 电路结构。

# 表 2-2. 引脚 I/O 电路类型(1/2)

| 引脚名称                             | I/O 电路类型 | I/O | 未使用引脚的建议连接方式                                                                                       |
|----------------------------------|----------|-----|----------------------------------------------------------------------------------------------------|
| P00/TI000                        | 5-AH     | I/O | 输入: 通过电阻单独连接至 EVDD 或 EVss                                                                          |
| P01/TI010/TO00                   |          |     | 输出: 保持开路                                                                                           |
| P02/SO11                         | 5-AG     |     |                                                                                                    |
| P03/SI11                         | 5-AH     |     |                                                                                                    |
| P04/SCK11                        |          |     |                                                                                                    |
| P05/Tl001/SSI11                  | _        |     |                                                                                                    |
| P06/TI011/TO01                   |          |     |                                                                                                    |
| P10/SCK10/TxD0                   |          |     |                                                                                                    |
| P11/SI10/RxD0                    |          |     |                                                                                                    |
| P12/SO10                         | 5-AG     |     |                                                                                                    |
| P13/TxD6                         |          |     |                                                                                                    |
| P14/RxD6                         | 5-AH     |     |                                                                                                    |
| P15/TOH0                         | 5-AG     |     |                                                                                                    |
| P16/TOH1/INTP5                   | 5-AH     |     |                                                                                                    |
| P17/TI50/TO50                    |          |     |                                                                                                    |
| P20/ANI0 至 P27/ANI7 <sup>推</sup> | 11-G     | 输入  | <模拟设置>         连接至 AVREF 或 AVss         <数字设置>         输入: 通过电阻单独连接至 EVDD 或 EVss         输出: 保持开路。 |
| P30/INTP1 至 P32/INTP3            | 5-AH     | I/O | 输入: 通过电阻单独连接至 EVop 或 EVss                                                                          |
| P33/TI51/至 51/INTP4              |          |     | 输出: 保持开路                                                                                           |
| P40 至 P47                        | 5-AG     |     |                                                                                                    |
| P50 至 P57                        |          |     |                                                                                                    |
| P60/SCL0                         | 13-AD    |     | 输入: 连接至 EVss                                                                                       |
| P61/SDA0                         |          |     | 输出: 将端口的输出锁存器清零后,该引脚保持低电平输出                                                                        |
| P62/EXSCL0                       |          |     |                                                                                                    |
| P63                              | 13-P     |     |                                                                                                    |
| P64 至 P67                        | 5-AG     | 7   | 输入: 通过电阻单独连接至 EVop 或 EVss                                                                          |
| P70/KR0 至 P77/KR7                | 5-AH     |     | 输出: 保持开路                                                                                           |
| P120/INTP0/EXLVI                 |          |     |                                                                                                    |

注: 复位后, P20/ANIO 至 P27/ANI7 被设置为模拟输入模式。

# 表 2-2. 引脚 I/O 电路类型 (2/2)

|   | 引脚名称                           | I/O 电路类型 | I/O | 未使用引脚的建议连接方式                                           |
|---|--------------------------------|----------|-----|--------------------------------------------------------|
| * | P121/X1 <sup>± 1</sup>         | 37       | I/O | 输入: 通过电阻单独连接至 VDD 或 Vss                                |
| * | P122/X2/EXCLK * 1              |          |     | 输出: 保持开路                                               |
| * | P123/XT1 <sup>±1</sup>         |          |     |                                                        |
| * | P124/XT2/EXCLKS <sup>± 1</sup> |          |     |                                                        |
|   | P130                           | 3-C      | 输出  | 保持开路                                                   |
|   | P140/PCL/INTP6                 | 5-AH     | I/O | 输入: 通过电子单独连接至 EVDD 或 EVss                              |
|   | P141/BUZ/BUSY0/INTP7           |          |     | 输出: 保持开路                                               |
|   | P142/SCKA0                     |          |     |                                                        |
|   | P143/SIA0                      |          |     |                                                        |
|   | P144/SOA0                      | 5-AG     |     |                                                        |
|   | P145/STB0                      |          |     |                                                        |
|   | AVREF                          | -        | 1   | 直接连接至 EV <sub>DD</sub> 或 V <sub>DD</sub> <sup>维2</sup> |
|   | AVss                           | =        | =   | 直接连接至 EVss 或 Vss                                       |
|   | FLMD0                          | 38       | =   | 连接至 EVss 或 Vss                                         |
|   | RESET                          | 2        | 输入  | _                                                      |

- **注:** 1. 当这些引脚未被使用时,请使用如上 I/O 端口模式下的建议连接方式(参见**图 6-2 时钟操作模式选择寄 存器(OSCCTL)的格式**)。
  - 2. 当端口 2 作为数字端口使用时,使其电平与 Voo 引脚相同。

图 2-1. 引脚 I/O 电路列表(1/2)



图 2-1. 引脚 I/O 电路列表 (2/2)



### 第三章 CPU 结构

### 3.1 存储空间

**78K0/KF2** 产品可以访问大小为 **64KB** 的存储空间。图 **3-1**  $\sim$  **3-5** 显示了存储空间映射图。

- 注意事项: 1. 不管内存容量有多少,内存容量切换寄存器(IMS)和所有 78K0/KF2 产品的内部扩展 RAM 容量切换寄存器(IXS)的初始值都是固定的(IMS = CFH, IXS = 0CH)。因此每种产品设置值如下所示。
  - 2. 如果要设置存储器容量,应先设置 IMS,再设置 IXS。设置了存储器容量,内部 ROM 和内部扩展 RAM 区域就不会重叠了。

表 3-1 设置内存容量切换寄存器(IMS)和内部扩展 RAM 容量切换寄存器(IXS)的值

| 闪存版本<br>(78K0/KF2)   | IMS              | IXS | ROM 容量              | 内部高速 RAM 容量 | 内部扩展 RAM 容量 |
|----------------------|------------------|-----|---------------------|-------------|-------------|
| μPD78F0544           | ССН              | 0AH | 48 KB               | 1 KB        | 1 KB        |
| μPD78F0545           | CFH              | 08H | 60 KB               |             | 2 KB        |
| μPD78F0546           | CCH <sup>≇</sup> | 04H | 96 KB <sup>≇</sup>  |             | 4 KB        |
| μPD78F0547, 78F0547D | CCH <sup>≇</sup> | 00H | 128 KB <sup>≇</sup> |             | 6 KB        |

注: μPD78F0546、78F0547 和μPD78F0547D 各自拥有 96KB 和 128KB 的内部 ROM。但是,由于使用了存储器组,这些设备的内存容量切换寄存器(IMS)设置值和那些拥有 48KB 内容 ROM 的产品是一样的。如需了解存储器组的设置情况,参见 **4.2 存储器组选择寄存器(BANK)**。

### 图 3-1 存储空间映射图 (μPD78F0544)



- 注: 1. 当不使用引导交换功能的时候:设置选项字节区域:  $0080H \sim 0084H$ 。 当使用引导交换功能的时候: 设置选项字节区域:  $0080H \sim 0084H$  和  $1080H \sim 1084H$ 。
  - 2. 根据安全设置可以禁止写入引导簇 0 (参见 27.8 安全设置)。

### 图 3-2 存储空间映射图 (µPD78F0545)



- 注: 1. 当不使用引导交换功能的时候: 设置选项字节区域:  $0080H \sim 0084H$ 。 当使用引导交换功能的时候: 设置选项字节区域:  $0080H \sim 0084H$  和  $1080H \sim 1084H$ 。
  - 2. 根据安全设置可以禁止写入引导簇 0 (参见 27.8 安全设置)。

### 图 3-3 存储空间映射图 (μPD78F0546)



- **注:** 1. 当不使用引导交换功能的时候:设置选项字节区域:0080H~0084H。 当使用引导交换功能的时候:设置选项字节区域:0080H~0084H和1080H~1084H。
  - 2. 根据安全设置可以禁止写入引导簇 0 (参见 27.8 安全设置)。

### 图 3-4 存储空间映射图 (µPD78F0547)



- **注:** 1. 当不使用引导交换功能的时候:设置选项字节区域:0080H  $\sim$  0084H。 当使用引导交换功能的时候:设置选项字节区域:0080H  $\sim$  0084H 和 1080H  $\sim$  1084H。
  - 2. 根据安全设置可以禁止写入引导簇 0 (参见 27.8 安全设置)。

### 图 3-5 存储空间映射图 (µPD78F0547D)



**注: 1.** 当不使用引导交换功能的时候:设置选项字节区域: 0080H  $\sim$  0084H,以及片上调试安全 ID 区域: 0085H  $\sim$  008EH。

当使用引导交换功能的时候: 设置选项字节 0080H  $\sim$  0084H 和 1080H  $\sim$  1084H,以及片上调试安全 ID 区域: 0085H  $\sim$  008EH 和 1085H  $\sim$  - 108EH。

2. 根据安全设置可以禁止写入引导簇 0 (参见 27.8 安全设置)。

### 3.1.1 内部程序存储空间

内部程序存储空间用于存储程序和表数据,一般通过程序计数器(PC)来寻址。 78K0/KF2 产品内部 ROM(闪存)的情况如下表所示。

表 3-2 内部 ROM 容量

| 产品型号                    | 内部 ROM |                                                                                     |  |  |  |  |  |  |
|-------------------------|--------|-------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                         | 结构     | 容量                                                                                  |  |  |  |  |  |  |
| μPD78F0544              | 闪存     | 49152 × 8 位 (0000H ~ BFFFH)                                                         |  |  |  |  |  |  |
| μPD78F0545              |        | 61440×8位 (0000H~EFFFH)                                                              |  |  |  |  |  |  |
| μPD78F0546              |        | 98304 × 8 位<br>(0000H ~ 7FFFH (公共区域: 32 KB) + 8000H - BFFFH (存储器组区域: 16 KB) × 4)    |  |  |  |  |  |  |
| μPD78F0547,<br>78F0547D |        | 131072 × 8 位<br>(0000H ~ - 7FFFH (公共区域: 32 KB) + 8000H - BFFFH (存储器组区域: 16 KB) × 6) |  |  |  |  |  |  |

内部程序存储空间主要分为以下几个区域。

# (1) 向量表区域

从 0000H 到 003FH 总共 64 字节作为向量表区域。在向量表中存放的是根据复位信号输入或每个中断请求的产生进行转移的程序的起始地址。

在16位地址中,低8位是偶地址,高8位是奇地址。

表 3-3 向量表

| 向量表地址 | 中断源                     | 向量表地址 | 中断源            |
|-------|-------------------------|-------|----------------|
| 0000H | RESET 输入, POC, LVI, WDT | 0022H | INTTM010       |
| 0004H | INTLVI                  | 0024H | INTAD          |
| 0006H | INTP0                   | 0026H | INTSR0         |
| 0008H | INTP1                   | 0028H | INTWTI         |
| 000AH | INTP2                   | 002AH | INTTM51        |
| 000CH | INTP3                   | 002CH | INTKR          |
| 000EH | INTP4                   | 002EH | INTWT          |
| 0010H | INTP5                   | 0030H | INTP6          |
| 0012H | INTSRE6                 | 0032H | INTP7          |
| 0014H | INTSR6                  | 0034H | INTIIC0/INTDMU |
| 0016H | INTST6                  | 0036H | INTCSI11       |
| 0018H | INTCSI10/INTST0         | 0038H | INTTM001       |
| 001AH | INTTMH1                 | 003AH | INTTM011       |
| 001CH | INTTMH0                 | 003CH | INTACSI        |
| 001EH | INTTM50                 | 003EH | BRK            |
| 0020H | INTTM000                |       |                |

### (2) CALLT 指令表区域

0040H至007FH共64字节的区域,可存放1字节调用指令(CALLT)的子程序入口地址。

# ★(3) 选项字节区域

0080H  $\sim$  0084H 和 1080H  $\sim$  1084H 各 5 字节的区域可以用作选项字节区域。当不使用引导交换功能时,在 0080H  $\sim$  0084H 设置选项字节;而当使用引导交换功能时,在 0080H  $\sim$  0084H 和 1080H  $\sim$  1084H 设置选项字节。详细信息参见**第二十六章 选项字节**。

#### (4) CALLF 指令入口区域

0800H ~ 0FFFH 的区域,用于子程序的直接调用,通过一个 2 字节的调用指令(CALLF)实现。

#### ★ (5) 片上调试安全 ID 设置区域 (仅用于 uPD78F0547D)

0085H  $\sim$  008EH 和 1085H  $\sim$  108EH 各 10 字节区域可用作片上调试安全 ID 设置区域。不使用引导交换功能时,在 0085H  $\sim$  008EH 区域设置片上调试安全 ID; 而当使用引导交换功能时,在 0085H  $\sim$  008EH 和 1085H  $\sim$  108EH 区域设置。详细情况请参见**第二十八章 片上调试功能 (仅用于\muPD78F0547D)**。

### ★ 3.1.2 存储器组 (仅用于 µPD78F0546, 78F0547 和 78F0547D)

在 $\mu$ PD78F0546 中,8000H  $\sim$  BFFFH 共 16KB 的空间分配给存储器组 0  $\sim$  3,在 $\mu$ PD78F0547 和 78F0547D 中则分配给存储器组 0  $\sim$  5。

这些组是通过存储器组选择寄存器(BANK)进行选择的。详细情况请参见**第四章 存储器组选择功能(仅用于** μPD78F0546, 78F054778F0547D)。

### 注意事项 1. 不能在不同的存储器组之间获取指令。

- 2. 不能在不同的存储器组之间直接进行转移和访问。必须通过公共区域执行不同存储器组之间的转移或访问操作。
- 3. 在公共区域中分配中断服务程序。
- 4. 扩展到 7FFFH  $\sim$  8000H 的指令只能在存储器组 0 中执行。

### 3.1.3 内部数据存储空间

78K0/KF2产品包括以下几种 RAM。

### (1) 内部高速 RAM

表 3-4 内部高速 RAM 容量

| 产品型号                 | 内部高速 RAM                      |
|----------------------|-------------------------------|
| μPD78F0544           | 1024×8 位 (FB00H $\sim$ FEFFH) |
| μPD78F0545           |                               |
| μPD78F0546           |                               |
| μPD78F0547, 78F0547D |                               |

FEE0H ~ FEFFH 共 32 字节的区域分配给 4 组通用寄存器,每组都由 8 个 8 位寄存器组成。这个区域不可以用作写和执行指令的程序区域。 内部高速 RAM 还可以作为堆栈存储器使用。

### (2) 内部扩展 RAM

表 3-5 内部扩展 RAM 容量

| 产品型号                 | 内部扩展 RAM                   |
|----------------------|----------------------------|
| μPD78F0544           | 1024×8 位 (F400H~ F7FFH)    |
| μPD78F0545           | 2048×8位 (F000H~F7FFH)      |
| μPD78F0546           | 4096 × 8 位 (E800H ~ F7FFH) |
| μPD78F0547, 78F0547D | 6144×8位 (E000H~F7FFH)      |

与内部高速 RAM 类似,内部扩展 RAM 可作为普通数据区域,同时也可作为写和执行指令的程序存储区域。内部扩展 RAM 不能用作堆栈。

## 3.1.4 特殊功能寄存器(SFR)区域

片內外围硬件的特殊功能寄存器 (SFR)被分配在 FF00H  $\sim$  FFFFH 的区域 (参见 **3.2.3 特殊功能寄存器(SFR)**中**表 3-6 特殊功能寄存器列表)**。

注意事项:不要访问那些未分配特殊功能寄存器的地址区域。

# 3.1.5 数据存储空间寻址

寻址是定位地址的方式,需要定位的地址包括下一条指令地址或者与指令执行相关的存储器地址或寄存器地址。

基于可操作性和其他考虑,在 78K0/KF2 中提供了几种用于与指令执行相关的存储器寻址方式。因为有专门的数据存储区域,故可使用一些特殊的寻址方式,具有特殊功能寄存器(SFR)和通用寄存器的功能。图 3-6 和 3-9 显示了数据存储空间与寻址方式的对应关系。如需了解每种寻址方式的详细内容,参见 3.4 操作数地址寻址。



图 3-6 数据存储空间与寻址方式的对应关系 (µPD78F0544)



图 3-7 数据存储空间与寻址方式的对应关系 (µPD78F0545)



图 3-8 数据存储空间与寻址方式的对应关系 (µPD78F0546)

★ 注: 如果要转移到一个存储器组或对该存储器组寻址(该存储器组没有根据存储器组选择寄存器(BANK)进行设置),则要使用 BANK 先对该存储器组进行设置。



图 3-9 数据存储空间与寻址方式的对应关系 (µPD78F0547, 78F0547D)

★ **注:** 如果要转移到一个存储器组或对该存储器组寻址(该存储器组没有根据存储器组选择寄存器(BANK)进行设置),则要使用 BANK 先对该存储器组进行设置。

#### 3.2 处理器寄存器

The 78K0/KF2产品包含以下几种处理器寄存器。

### 3.2.1 控制寄存器

控制寄存器用于控制程序执行的顺序、状态和堆栈空间。程序计数器(PC)、程序状态字(PSW)和堆栈指针寄存器(SP)都属于控制寄存器。

#### (1) 程序计数器 (PC)

程序计数器是一个16位寄存器,用于存放下一条即将要执行的指令的地址。

在正常情况下,根据获取的指令字节数,程序计数器(PC)的值会自动累加。当执行分支指令时,则设置立即数和寄存器内容。

复位信号的产生将复位向量表中地址为 0000H 和 0001H 中的值赋给程序计数器。

#### 图 3-10 程序计数器格式



### (2) 程序状态字 (PSW)

程序状态字(PSW)是一个8位寄存器,由各种标志位组成,通过指令执行对其进行设置或复位。

根据中断请求的产生或 PUSH PSW 指令执行,程序状态字的内容自动入栈;通过执行 RETB,RETI 和 POP PSW 指令,程序状态字的值自动恢复。

复位信号的产生将程序状态字的内容设置为 02H。

图 3-11 程序状态字格式



### (a) 中断允许标志(IE)

该标志用于控制 CPU 响应中断请求操作。

当 IE 为 0 时,表示不允许中断(DI),即禁止所有可屏蔽中断请求。

当 IE 为 1 时,表示允许中断(EI),通过优先服务标志(ISP)、用于各种中断源的中断屏蔽标志以及优先级规定标志来完成响应中断请求的控制。

当执行 DI 指令或中断请求得到响应时,该标志复位(0);当执行 EI 指令时,该标志设置为 1。

### (b) 零标志 (Z)

当操作结果为0时,该标志置1,其他情况置0。

### (c) 寄存器组选择标志 (RBS0 和 RBS1)

寄存器组选择标志有两位,用于选择四组寄存器中的一组。 标志位中存储的信息用来指明执行 SEL RBn 指令时所选择的寄存器组。

### (d) 半进位标志 (AC)

如果操作结果中第3位有进位或在第3位上有借位,则该标志置1。其他情况该标志置0。

### (e) 优先服务标志 (ISP)

该标志用来管理可屏蔽向量中断响应的优先级。当 ISP 为 0 时,由优先级指定标志寄存器(PR0L, PR0H, PR1L, PR1H)(参见 20.3 (3) 优先级指定标志寄存器(PR0L, PR0H, PR1L, PR1H))指定为低优先级的向量中断请求被禁止响应。对请求的实际响应是由中断允许标志(IE)的状态控制的。

### (f) 进位标志(CY)

该标志存储的是在执行加减指令时出现的进位或借位。它也存储循环指令执行中的转移值,还可以在位操作指令执行中作为位累加器使用。

# (3) 堆栈指针 (SP)

这是一个 16 位的寄存器,用来存放存储器堆栈区的起始地址。只有内部高速 RAM 区域才能被设置为堆栈区。

图 3-12 堆栈指针格式



在向堆栈写(存)数据时,堆栈指针 SP 递减,而从堆栈中读出(恢复)数据时,堆栈指针累加。 堆栈的数据存储/恢复操作过程如图 3-13 和 3-14 所示。

注意事项:由于复位信号产生时,SP的内容不确定,所以在使用堆栈前必须先对SP初始化。

### 图 3-13 将数据存入堆栈

# (a) PUSH rp 指令 (当 SP = FEE0H)



# (b) CALL, CALLF, CALLT 指令 (当 SP = FEE0H)



# (c) 中断, BRK 指令 (当 SP = FEE0H)



### 图 3-14 从堆栈读出数据

# (a) PUSH rp 指令 (当 SP = FEDEH)



# (b) RET 指令 (当 SP = FEDEH)



# (c) RETI, RETB 指令 (当 SP = FEDDH)



### 3.2.2 通用寄存器

通用寄存器映射到数据存储器特定的地址空间为 FEE0H  $\sim$  FEFFH。通用寄存器共有四组,每一组由 8 个 8 位寄存器(X, A, C, B, E, D, L 和 H)组成。

此外每个寄存器可作为一个 8 位寄存器使用,两个成对的 8 位寄存器可作为一个 16 位寄存器(AX, BC, DE 和 HL)使用。

描述通用寄存器时,可以使用功能名称(X, A, C, B, E, D, L, H, AX, BC, DE 和 HL)或绝对名称(R0  $\sim$  R7, RP0  $\sim$  RP3)。

用于指令执行的寄存器组由 CPU 控制指令(SEL RBn)来设置。由于 4 个寄存器组的结构,通过一个用于正常处理的寄存器和另一个用于中断处理的寄存器之间的切换,可以创建一个高效率的程序。

### 图 3-15 通用寄存器结构

### (a) 功能名称



### (b) 绝对名称



### 3.2.3 特殊功能寄存器 (SFR)

与通用寄存器不同,每个特殊功能寄存器都有特定的功能。

特殊寄存器指定在FF00H到FFFFH区域。

特殊功能寄存器可像通用寄存器那样用运算指令、传送指令以及位操作指令进行操作。根据特殊功能寄存器的类型不同,可操作的位单元也不同,可以是1位、8位和16位。

每种位单元操作的描述如下。

#### 1位操作

1 位操作指令的操作数(sfr.bit)被描述为汇编程序的保留符号。该操作也可由一个地址来定义。

### 8位操作

8 位操作指令的操作数(sfr)被描述为汇编程序的保留符号。 该操作也可由一个地址来定义。

### • 16位操作

16 位操作指令的操作数(sfrp) 被描述为汇编程序的保留符号。 寻址时表示为一个偶地址。

表 3-6 为特殊功能寄存器列表。表中术语的含义如下。

# • 符号

表示特殊功能寄存器地址的符号,在 RA78K0 中是保留字,并使用 CC78K0 中的#pragma sfr 指令定义为一个 sfr 变量。在使用 RA78K0, ID78K0-QB 和 78K0/KX2 的 SM+时,可以将符号作为指令操作数执行写操作。

#### R/W

表示特殊功能寄存器可读或可写。

R/W: 可读/写

R: 只读

W: 只写

• 可操作的位单元

表示可操作的位单元 (1, 8, 或 16)。 "-" 表示不可操作的位单元。

• 复位后

表示复位信号产生后每个寄存器的状态

表 3-6 特殊功能寄存器列表(1/4)

| 地址    | 特殊功能寄存器(SFR)名称      | 一<br>一<br>符号 | R/W | 可操作位单元   |          |      | 复位后   |
|-------|---------------------|--------------|-----|----------|----------|------|-------|
|       | ,,,,,,              |              |     | 1位       | 8位       | 16 位 | 1     |
| FF00H | 端口寄存器 0             | P0           | R/W | √        | V        | _    | 00H   |
| FF01H | 端口寄存器 1             | P1           | R/W | √        | V        | _    | 00H   |
| FF02H | 端口寄存器 2             | P2           | R/W | √        | V        | _    | 00H   |
| FF03H | 端口寄存器 3             | P3           | R/W | √        | V        | _    | 00H   |
| FF04H | 端口寄存器 4             | P4           | R/W | √        | √        | _    | 00H   |
| FF05H | 端口寄存器 5             | P5           | R/W | <b>√</b> | V        | _    | 00H   |
| FF06H | 端口寄存器 6             | P6           | R/W | √        | V        | _    | 00H   |
| FF07H | 端口寄存器 7             | P7           | R/W | <b>√</b> | V        | _    | 00H   |
| FF08H | 10 位 A/D 转换结果寄存器    | ADCR         | R   | -        | _        | √    | 0000H |
| FF09H | 8 位 A/D 转换结果寄存器     | ADCRH        | R   | =        | √        | _    | 00H   |
| FF0AH | 接收缓冲寄存器 6           | RXB6         | R   | _        | V        | _    | FFH   |
| FF0BH | 发送缓冲寄存器 6           | TXB6         | R/W | _        | V        | _    | FFH   |
| FF0CH | 端口寄存器 12            | P12          | R/W | √        | V        | _    | 00H   |
| FF0DH | 端口寄存器 13            | P13          | R/W | √        | V        | _    | 00H   |
| FF0EH | 端口寄存器 14            | P14          | R/W | √        | √        | _    | 00H   |
| FF0FH | 串行 I/O 移位寄存器 10     | SIO10        | R   | =        | √        | _    | 00H   |
| FF10H | 16位定时器计数器 00        | TM00         | R   | =        | _        | √    | 0000H |
| FF11H | 1                   |              |     |          |          |      |       |
| FF12H | 16 位定时器捕获/比较寄存器 000 | CR000        | R/W | _        | _        | √    | 0000H |
| FF13H |                     |              |     |          |          |      |       |
| FF14H | 16 位定时器捕获/比较寄存器 010 | CR010        | R/W | -        | -        | √    | 0000H |
| FF15H | 1                   |              |     |          |          |      |       |
| FF16H | 8位定时器计数器 50         | TM50         | R   | 1        | √        | _    | 00H   |
| FF17H | 8 位定时器比较寄存器 50      | CR50         | R/W | -        | √        | _    | 00H   |
| FF18H | 8 位定时器 H 比较寄存器 00   | CMP00        | R/W | -        | <b>√</b> | _    | 00H   |
| FF19H | 8位定时器 H 比较寄存器 10    | CMP10        | R/W | -        | √        | -    | 00H   |
| FF1AH | 8 位定时器 H 比较寄存器 01   | CMP01        | R/W | -        | V        | _    | 00H   |
| FF1BH | 8 位定时器 H 比较寄存器 11   | CMP11        | R/W | 1        | √        | _    | 00H   |
| FF1FH | 8位定时器 计数器 51        | TM51         | R   | -        | √        | -    | 00H   |
| FF20H | 端口模式寄存器 0           | PM0          | R/W | √        | √        | -    | FFH   |
| FF21H | 端口模式寄存器 1           | PM1          | R/W | <b>√</b> | <b>√</b> | _    | FFH   |
| FF22H | 端口模式寄存器 3           | PM2          | R/W | <b>√</b> | <b>√</b> | _    | FFH   |
| FF23H | 端口模式寄存器 4           | PM3          | R/W | <b>√</b> | V        | _    | FFH   |
| FF24H | 端口模式寄存器 5           | PM4          | R/W | √        | √        | _    | FFH   |
| FF25H | 端口模式寄存器 6           | PM5          | R/W | √        | √        | -    | FFH   |
| FF26H | 端口模式寄存器 7           | PM6          | R/W | √        | √        | _    | FFH   |
| FF27H | A/D 转换器模式寄存器        | PM7          | R/W | √        | √        | _    | FFH   |
| FF28H | 模拟输入通道选择寄存器         | ADM          | R/W | √        | √        | _    | 00H   |
| FF29H | 8 位定时器计数器 50        | ADS          | R/W | √        | √        | _    | 00H   |
| FF2CH | 端口模式寄存器 12          | PM12         | R/W | √        | √        | _    | FFH   |
| FF2EH | 端口模式寄存器 14          | PM14         | R/W | √        | √        | -    | FFH   |
| FF2FH | A/D 端口配置寄存器         | ADPC         | R/W | <b>√</b> | <b>√</b> | _    | 00H   |

# 表 3-6 特殊功能寄存器列表 (2/4)

| 地址    | 表 3-6 特殊<br>特殊功能寄存器 (SFR)名称          |       | <del>17 66</del> グリイ<br>F号 | R/W   |        | 可操作位单を   | 可操作位单元 |     |  |
|-------|--------------------------------------|-------|----------------------------|-------|--------|----------|--------|-----|--|
| 76.m. | 13 //10/3 113 33 13 141 (62 23) [21] | 1.    | , ,                        | 10 11 | 1位     | 8位       | 16 位   | 复位后 |  |
| FF30H | 上拉电阻选择寄存器 0                          | PU0   |                            | R/W   | √ √    | √        | _      | 00H |  |
| FF31H | 上拉电阻选择寄存器 1                          | PU1   |                            | R/W   | √      | V        | =      | 00H |  |
| FF33H | 上拉电阻选择寄存器 3                          | PU3   |                            | R/W   | √      | V        | _      | 00H |  |
| FF34H | 上拉电阻选择寄存器 4                          | PU4   |                            | R/W   | √      | V        | =      | 00H |  |
| FF35H | 上拉电阻选择寄存器 5                          | PU5   |                            | R/W   | √      | V        | _      | 00H |  |
| FF36H | 上拉电阻选择寄存器 6                          | PU6   |                            | R/W   | √      | V        | _      | 00H |  |
| FF37H | 上拉电阻选择寄存器 7                          | PU7   |                            | R/W   | √      | V        | _      | 00H |  |
| FF3CH | 上拉电阻选择寄存器 12                         | PU12  |                            | R/W   | √      | √        | -      | 00H |  |
| FF3EH | 上拉电阻选择寄存器 14                         | PU14  |                            | R/W   | √      | √        | -      | 00H |  |
| FF40H | 时钟输出选择寄存器                            | CKS   |                            | R/W   | √      | V        | -      | 00H |  |
| FF41H | 8位定时器比较寄存器 51                        | CR51  |                            | R/W   | =      | <b>V</b> | -      | 00H |  |
| FF43H | 8位定时器模式控制寄存器 51                      | TMC5  | 1                          | R/W   | √      | V        | -      | 00H |  |
| FF48H | 外部中断上升沿使能寄存器                         | EGP   |                            | R/W   | √      | <b>V</b> | -      | 00H |  |
| FF49H | 外部中断下降沿使能寄存器                         | EGN   |                            | R/W   | √      | V        | =      | 00H |  |
| FF4AH | 串行 I/O 移位寄存器 11                      | SIO11 |                            | R     | -      | V        | -      | 00H |  |
| FF4CH | 发送缓冲寄存器 11                           | SOTB  | 11                         | R/W   | -      | V        | -      | 00H |  |
| FF4FH | 输入切换控制寄存器                            | ISC   |                            | R/W   | √      | V        | -      | 00H |  |
| FF50H | 异步串行接口操作模式寄存器 6                      | ASIM6 | ASIM6                      |       | √      | V        | _      | 01H |  |
| FF53H | 异步串行接口接收错误状态寄存器 6                    | ASIS6 | ASIS6                      |       | -      | V        | _      | 00H |  |
| FF55H | 异步串行接口传送状态寄存器 6                      | ASIF6 |                            | R     | -      | √        | -      | 00H |  |
| FF56H | 时钟选择寄存器 6                            | CKSR  | 6                          | R/W   | -      | √        | -      | 00H |  |
| FF57H | 波特率发生器控制寄存器 6                        | BRGC  | 6                          | R/W   | -      | √        | -      | FFH |  |
| FF58H | 异步串行接口控制寄存器 6                        | ASICL | 6                          | R/W   | √      | <b>√</b> | -      | 16H |  |
| FF60H | 余数寄存器 0                              | SDR0  | SDR0L                      | R     | -      | √        | √      | 00H |  |
| FF61H |                                      |       | SDR0H                      |       |        | √        |        | 00H |  |
| FF62H | 乘/除数寄存器 A0                           | MDA0L | MDA0LL                     | R/W   | _      | V        | √      | 00H |  |
| FF63H |                                      |       | MDA0LH                     |       | =      | √        |        | 00H |  |
| FF64H |                                      | MDA0H | MDA0HL                     | R/W   | _      | √        | √      | 00H |  |
| FF65H |                                      |       | MDA0HH                     |       | -      | √        |        | 00H |  |
| FF66H | 乘/除数寄存器 B0                           | MDB0  | MDB0L                      | R/W   |        | √<br>,   | √      | 00H |  |
| FF67H |                                      |       | MDB0H                      | R/W   |        | √        |        | 00H |  |
| FF68H | 乘法器/除法器控制寄存器 0                       |       | DMUC0                      |       | √<br>  | √<br>,   | -      | 00H |  |
| FF69H | 8位定时器 H 模式寄存器 0                      |       | TMHMD0                     |       | √<br>  | √        | =      | 00H |  |
| FF6AH | 定时器时钟选择寄存器 50                        |       | TCL50                      |       | √<br>/ | √<br>/   | _      | 00H |  |
| FF6BH | 8位定时器模式控制寄存器 50                      | TMC50 |                            | R/W   | √<br>  | √<br>/   | _      | 00H |  |
| FF6CH | 8位定时器 H 模式寄存器 1                      | TMHM  |                            | R/W   | √<br>  | √<br>,   | =      | 00H |  |
| FF6DH | 8位定时器 H 载波控制寄存器 1                    | TMCY  | C1                         | R/W   | √<br>  | √<br>,   | _      | 00H |  |
| FF6EH | 按键返回模式寄存器                            | KRM   |                            | R/W   | √<br>  | √<br>,   | _      | 00H |  |
| FF6FH | 钟表定时器操作模式寄存器                         | WTM   |                            | R/W   | √      | V        | _      | 00H |  |

表 3-6 特殊功能寄存器列表 (3/4)

| 地址    | 特殊功能寄存器 (SFR)名称   | 符号     | R/W |              | 可操作位单之       | 元    | 复位后                |
|-------|-------------------|--------|-----|--------------|--------------|------|--------------------|
|       |                   |        | •   | 1位           | 8位           | 16 位 |                    |
| FF70H | 异步串行接口操作模式寄存器 0   | ASIM0  | R/W | √            | √            | -    | 01H                |
| FF71H | 波特率发生器控制寄存器 0     | BRGC0  | R/W | _            | √            | -    | 1FH                |
| FF72H | 接收缓冲寄存器 0         | RXB0   | R   | _            | √            | -    | FFH                |
| FF73H | 异步串行接口接收错误状态寄存器 0 | ASIS0  | R   | _            | √            | -    | 00H                |
| FF74H | 发送移位寄存器 0         | TXS0   | W   | _            | √            | -    | FFH                |
| FF80H | 串行操作模式寄存器 10      | CSIM10 | R/W | √            | √            | -    | 00H                |
| FF81H | 串行时钟选择寄存器 10      | CSIC10 | R/W | √            | √            | -    | 00H                |
| FF84H | 发送缓冲寄存器 10        | SOTB10 | R/W | _            | √            | -    | 00H                |
| FF88H | 串行操作模式寄存器 11      | CSIM11 | R/W | √            | √            | -    | 00H                |
| FF89H | 串行时钟选择寄存器 11      | CSIC11 | R/W | √            | √            | -    | 00H                |
| FF8CH | 定时器时钟选择寄存器 51     | TCL51  | R/W | √            | √            | -    | 00H                |
| FF90H | 串行操作模式选择寄存器 0     | CSIMA0 | R/W | √            | √            | -    | 00H                |
| FF91H | 串行状态寄存器 0         | CSIS0  | R/W | √            | √            | -    | 00H                |
| FF92H | 串行触发寄存器 0         | CSIT0  | R/W | √            | √            | -    | 00H                |
| FF93H | 除数选择寄存器 0         | BRGCA0 | R/W | -            | √            | -    | 03H                |
| FF94H | 自动数据传送地址指针指定存储器 0 | ADTP0  | R/W | _            | √            | -    | 00H                |
| FF95H | 自动数据传送间隔指定寄存器 0   | ADTI0  | R/W | -            | √            | -    | 00H                |
| FF96H | 串行 I/O 移位寄存器 0    | SIOA0  | R/W | -            | $\checkmark$ | -    | 00H                |
| FF97H | 自动数据传送地址计数寄存器 0   | ADTC0  | R   | -            | √            | -    | 00H                |
| FF99H | 看门狗定时器使能寄存器       | WDTE   | R/W | -            | V            | _    | 注 1<br>1AH/9AH     |
| FF9FH | 时钟操作模式选择寄存器       | OSCCTL | R/W | √            | √            | -    | 00H                |
| FFA0H | 内部振荡模式寄存器         | RCM    | R/W | √            | √            | -    | 80H <sup>推 2</sup> |
| FFA1H | 主时钟模式寄存器          | MCM    | R/W | √            | √            | -    | 00H                |
| FFA2H | 主 OSC 控制寄存器       | MOC    | R/W | √            | √            | -    | 80H                |
| FFA3H | 振荡稳定时间计数器的状态寄存器   | OSTC   | R   | √            | √            | -    | 00H                |
| FFA4H | 振荡稳定时间选择寄存器       | OSTS   | R/W | _            | √            | -    | 05H                |
| FFA5H | IIC 移位寄存器 0       | IIC0   | R/W | _            | √            | -    | 00H                |
| FFA6H | IIC 控制寄存器 0       | IICC0  | R/W | √            | $\checkmark$ | -    | 00H                |
| FFA7H | 从设备地址寄存器 0        | SVA0   | R/W | -            | $\checkmark$ | -    | 00H                |
| FFA8H | IIC 时钟选择寄存器 0     | IICCL0 | R/W | $\checkmark$ | $\checkmark$ | =    | 00H                |
| FFA9H | IIC 功能扩展寄存器 0     | IICX0  | R/W | √            | √            | =    | 00H                |
| FFAAH | IIC 状态寄存器 0       | IICS0  | R   | √            | √            | =    | 00H                |
| FFABH | IIC 标志寄存器 0       | IICF0  | R/W | $\checkmark$ | √            | -    | 00H                |
| FFACH | 复位控制标志寄存器         | RESF   | R   | =            | √            | -    | 00H <sup>推 3</sup> |

- **注: 1.** WDTE 的复位值由选项字节的设置决定。
  - **2.** 复位后该寄存器的值立即变为 00H, 但在等待高速内部振荡器的振荡精确稳定后,该寄存器值会自动变为 80H。
  - 3 RESF 的复位值会根据复位源的变化而变化。

表 3-6 特殊功能寄存器列表 (4/4)

| 地址    | 特殊功能寄存器 (SFR)名称                             | <b>沙水切肥町</b><br>符 | ·号   | R/W        |              | 可操作位单え    | T.        | 复位后                |
|-------|---------------------------------------------|-------------------|------|------------|--------------|-----------|-----------|--------------------|
|       |                                             |                   |      | =          | 1位           | 8位        | 16 位      |                    |
| FFB0H | 16 位定时器计数器 01                               | TM01              |      | R          | _            | -         | <b>√</b>  | 0000H              |
| FFB1H |                                             |                   |      |            |              |           |           |                    |
| FFB2H | 16 位定时器捕获/比较寄存器 001                         | CR00              | 1    | R/W        | -            | _         | √         | H0000              |
| FFB3H |                                             |                   |      |            |              |           |           |                    |
| FFB4H | 16位定时器捕获/比较寄存器 011                          | CR01              | 1    | R/W        | _            | _         | $\sqrt{}$ | 0000H              |
| FFB5H | 1.4.2.2.1.11.11.11.11.11.11.11.11.11.11.11. |                   |      | 5.044      | 1            | 1         |           | 0.011              |
| FFB6H | 16位定时器模式控制寄存器 01                            | TMC0<br>PRM0      |      | R/W<br>R/W | √<br>√       | √<br>√    | _         | 00H                |
| FFB7H | 预分频器模式寄存器 01                                |                   |      | -          | √            | -         | _         | 00H                |
| FFB8H | 捕获/比较控制寄存器 01                               | CRC0              |      | R/W        |              | √<br>     | _         | 00H                |
| FFB9H | 16 位定时器输出控制寄存器 01                           | TOC0              |      | R/W        |              | √<br>,    | _         | 00H                |
| FFBAH | 16 位定时器模式控制寄存器 00                           | TMC0              |      | R/W        | √<br>        | √<br>,    | -         | 00H                |
| FFBBH | 预分频器模式寄存器 00                                | PRM0              | -    | R/W        | <b>√</b>     | √<br>,    | -         | 00H                |
| FFBCH | 捕获/比较控制寄存器 00                               | CRC0              |      | R/W        | √            | √         | _         | 00H                |
| FFBDH | 16 位定时器输出控制寄存器 00                           | TOC0              | 0    | R/W        | √            | V         | -         | 00H                |
| FFBEH | 低电压检测寄存器                                    | LVIM              |      | R/W        | √            | V         | -         | 00H <sup>往 1</sup> |
| FFBFH | 低电压检测等级选择寄存器                                | LVIS              |      | R/W        | $\sqrt{}$    | V         | _         | 00H <sup>推1</sup>  |
| FFE0H | 中断请求标志寄存器 0L                                | IF0               | IF0L | R/W        | $\sqrt{}$    | √         | V         | 00H                |
| FFE1H | 中断请求标志寄存器 0H                                |                   | IF0H | R/W        | $\checkmark$ | $\sqrt{}$ |           | 00H                |
| FFE2H | 中断请求标志寄存器 1L                                | IF1               | IF1L | R/W        | $\checkmark$ | $\sqrt{}$ | $\sqrt{}$ | 00H                |
| FFE3H | 中断请求标志寄存器 1H                                |                   | IF1H | R/W        | $\checkmark$ | $\sqrt{}$ |           | 00H                |
| FFE4H | 中断屏蔽标志寄存器 OL                                | MK0               | MK0L | R/W        | $\checkmark$ | V         | √         | FFH                |
| FFE5H | 中断屏蔽标志寄存器 0H                                |                   | MK0H | R/W        | √            | √         |           | FFH                |
| FFE6H | 中断屏蔽标志寄存器 1L                                | MK1               | MK1L | R/W        | √            | V         | √         | FFH                |
| FFE7H | 中断屏蔽标志寄存器 1H                                |                   | MK1H | R/W        | √            | V         |           | FFH                |
| FFE8H | 优先级指定标志寄存器 OL                               | PR0               | PR0L | R/W        | $\sqrt{}$    | V         | V         | FFH                |
| FFE9H | 优先级指定标志寄存器 0H                               |                   | PR0H | R/W        | √            | √         | 1         | FFH                |
| FFEAH | 优先级指定标志寄存器 1L                               | PR1               | PR1L | R/W        | √            | √         | √         | FFH                |
| FFEBH | 优先级指定标志寄存器 1H                               |                   | PR1H | R/W        | √            | √         | 1         | FFH                |
| FFF0H | 内存容量切换寄存器 <sup>建2</sup>                     | IMS               |      | R/W        | _            | V         | -         | CFH                |
| FFF3H | 存储器组选择寄存器                                   | BANK              |      | R/W        | =            | V         |           | 00H                |
| FFF4H | 内部扩展 RAM 容量切换寄存器 <sup>#2</sup>              | IXS               |      | R/W        | =            | V         | -         | 0CH                |
| FFFBH | 处理器时钟控制寄存器                                  | PCC               |      | R/W        | $\sqrt{}$    | $\sqrt{}$ | _         | 01H                |

- 注: 1. LVIM 和 LVIS 的复位值随着复位源而变化。
  - 2. 不管内存容量有多大,内存容量切换寄存器(IMS)和所有 78K0/KF2 产品的内部扩展 RAM 容量切换寄存器 (IXS)的初始值都是固定的(IMS = CFH, IXS = 0CH)。因此每种产品设置值如下所示。

| 闪存版本                 | IMS | IXS | ROM 容量 | 内部高速 RAM 容量 | 内部扩展 RAM 容量 |
|----------------------|-----|-----|--------|-------------|-------------|
| (78K0/KF2)           |     |     |        |             |             |
| μPD78F0544           | ССН | 0AH | 48 KB  | 1 KB        | 1 KB        |
| μPD78F0545           | CFH | 08H | 60 KB  |             | 2 KB        |
| μPD78F0546           | ССН | 04H | 96 KB  |             | 4 KB        |
| μPD78F0547, 78F0547D | ССН | 00H | 128 KB |             | 6 KB        |

### 3.3 指令地址寻址

★ 一条指令的地址是由程序计数器(PC)和存储器组选择寄存器(BANK)决定的。根据执行指令时所获取的下一条指令字节数,程序计数器(PC)的内容自动增加(每个字节加 1)。在执行转移指令时,将程序计数器(PC)的内容设置为转移目的地址,并按以下寻址方式确定地址。(要了解每条指令的详细信息,请参阅 78K/0 系列指令用户手册(U12326E))。

### 3.3.1 相对寻址

#### [功能]

将一条指令的 8 位立即数(偏移量: jdisp8)与下一条指令的起始地址相加,结果赋给程序计数器(PC),然后转向相加结果指向的地址。这个偏移量是带符号数的补码(-128~+127),其中第7位是符号位。换句话说,在相对寻址中,分支的范围是从下一条指令起始地址的-128 到+127 之间。

当执行"BR \$addr16"指令或条件转移指令时,将执行相对寻址功能。

# [图示]



当S = 0,  $\alpha$  的所有位均为0 当S = 1,  $\alpha$  的所有位均为1

# 3.3.2 立即寻址

# [功能]

将指令中的立即数赋给程序计数器(PC),然后转向该地址。

在执行"CALL!addr16"指令、"BR!addr16"指令或"CALLF!addr11"指令时,将执行立即寻址功能。

CALL !addr16 和 BR !addr16 指令的转移地址范围是所有存储空间。但如果要转移到一个存储器组 (该存储器组 没有根据存储器组选择寄存器(BANK)进行设置),则要使用 BANK 先对该存储器组进行设置。

CALLF!addr11指令的转移地址范围在0800H与0FFFH之间。

### [图示]

CALL !addr16 和 BR !addr16 指令



### CALLF !addr11 指令



### 3.3.3 表间接寻址

### [功能]

通过指令码低 5 位的立即数(从第 1 位到第 5 位),访问特定存储区中表的内容(转移目的地址),并将表的内容赋给程序计数器(PC),然后转向该地址执行程序。

在执行 CALLT [addr5]指令时,进行表间接寻址。

★ 该指令访问的地址范围是表 40H~7FH 中所存储的地址,转移地址范围可以是整个存储器空间。但如果要转移到 一个存储器组 (该存储器组没有根据存储器组选择寄存器(BANK)进行设置),则要使用 BANK 先对该存储器组进行 设置。

### [图示]



### 3.3.4 寄存器寻址

## [功能]

将寄存器对(AX)的内容赋给程序计数器(PC),然后转向该地址。

"BR AX"指令将执行寄存器寻址功能。

# [图示]



### 3.4 操作数地址寻址

以下方法用来规定指令执行期间寄存器寻址和存储器寻址所进行的操作。

### 3.4.1 隐含寻址

# [功能]

这种寻址方式自动寻址通用寄存器中作为累加器(A 和 AX)使用的寄存器。在 78K0/KF2 系列指令中下列指令采用隐含寻址方式。

| 指令          | 隐含寻址所指定的寄存器             |
|-------------|-------------------------|
| MULU        | A 寄存器存放被乘数,AX 寄存器存放运算结果 |
| DIVUW       | AX 寄存器用于存放被除数和商         |
| ADJBA/ADJBS | 存放进行十进制调整后的数据           |
| ROR4/ROL4   | 存放用于数字循环的数字数据           |

### [操作数格式]

由于指令自动采用隐含寻址方式,所以没有特定的操作数格式。

### [举例]

以 MULU X 指令为例,这是一条 8 位乘 8 位的乘法运算指令,A 寄存器与 X 寄存器相乘的结果存放在 AX 中。在这个例子中 A 寄存器与 AX 寄存器均由隐含寻址方式指定。

# 3.4.2 寄存器寻址

### [功能]

寄存器寻址方式将通用寄存器作为操作数进行访问,并由寄存器组选择标志(RBS0 和 RBS1)和指令中的寄存器标识码,来指定需要访问的通用寄存器。

当具有下列操作数格式的指令执行时,采用寄存器寻址方式。如果使用 8 位寄存器,则指令码中有 3 位用来表示一个 8 位寄存器。

### [操作数格式]

| 标识符 | 描述                     |
|-----|------------------------|
| r   | X, A, C, B, E, D, L, H |
| rp  | AX, BC, DE, HL         |

'r' 和 'rp'可用绝对名称(R0  $\sim$  R7 以及 RP0  $\sim$  RP3)和功能名称(X, A, C, B, E, D, L, H, AX, BC, DE 以及 HL)来描述。

### [举例]

MOV A, C; 选择 C 寄存器作为 r



INCW DE;选择 DE 寄存器对作为 rp



# 3.4.3 直接寻址

# [功能]

存储器会根据指令字中的操作数地址进行直接寻址操作。

这种方式的寻址范围是整个存储空间。但如果要对一个存储器组寻址 (该存储器组没有根据存储器组选择寄存器 (BANK)进行设置),则要使用 BANK 先对该存储器组进行设置。

# [操作数格式]

| 标识符    | 描述          |
|--------|-------------|
| addr16 | 标号或 16 位立即数 |

### [举例]

MOV A, !0FE00H; 将!addr16 设置为 FE00H 时



### [图示]



### 3.4.4 短直接寻址

### [功能]

用指令中8位立即数直接对存储器的固定操作区域寻址。

该方式的寻址范围是 FE20H~FF1FH 总共 256 字节的区域。内部 RAM 和特殊功能寄存器(SFR)分别映射在 FE20H~ FEFFH 以及 FF00H~ FF1FH 的区域。

采用短直接寻址方式的特殊功能寄存器(SFR)区域(FF00H~FF1FH)是整个特殊功能寄存器 SFR 区域的一部分。程序中经常访问的端口、用作定时器和事件计数器的比较和捕捉寄存器都被映射到该区域。这些特殊功能寄存器(SFR)可以用很少的字节数和时钟数进行操作。

如果 8 位立即数是在 20H 和 FFH 之间,则将一个有效地址的第 8 位设置为 0;如果 8 位立即数是在 00H 与 1FH 之间,则一个有效地址的第 8 位设置为 1。参见下面的【图示】。

#### [操作数格式]

| 标识符    | 描述                              |
|--------|---------------------------------|
| saddr  | 标志或从 FE20H ~ FF1FH 的立即数         |
| saddrp | 标志或从 FE20H ~ FF1FH 的立即数(仅使用偶地址) |

### ★ [举例]

LB1 EQU 0FE30H ; 定义 FE30H 为 LB1.

.

MOV LB1, A ; 当 LB1 代表 saddr 区域的 FE30H 地址并且 A 寄存器的值就传送给这个地址时。



### [图示]



当8位立即数在20H与FFH之间时, $\alpha$  等于0 当 8位立即数的地址在 00H 与 1FH 之间时, $\alpha$  等于 1

### 3.4.5 特殊功能寄存器 (SFR)寻址

## [功能]

通过指令中的8位立即数对存储器的特殊功能寄存器(SFR)区域进行寻址。

寻址区间为 FF00H~FFCFH 以及 FFE0H~FFFFH,共 240 字节。而映射在 FF00H~FF1FH 区间的特殊功能寄存器则采用短直接寻址方式。

### [操作数格式]

| 标识符  | 描述                      |  |  |  |
|------|-------------------------|--|--|--|
| sfr  | 特殊功能寄存器名                |  |  |  |
| sfrp | 16 位可操作特殊功能寄存器名(仅使用偶地址) |  |  |  |

## [举例]

MOV PM0, A; 选择 PM0(FF20H)作为 sfr





### 3.4.6 寄存器间接寻址

## [功能]

根据寄存器对的内容进行寻址。该寄存器对由寄存器组选择标志(RBS0 和 RBS1)和指令字中的寄存器对指定码指定。

这种方式的寻址范围是整个存储空间。但如果要对一个存储器组寻址 (该存储器组没有根据存储器组选择寄存器 (BANK)进行设置),则要使用 BANK 先对该存储器组进行设置。

## [操作数格式]

| 标识符 | 描述         |
|-----|------------|
| -   | [DE], [HL] |

## [举例]

MOV A, [DE]; 选择 DE 寄存器对作为操作数时





### 3.4.7 基址寻址

### [功能]

将 8 位立即数加到 HL 寄存器对中,HL 寄存器对作为基地址寄存器。根据相加结果寻址。需要访问的 HL 寄存器对属于由寄存器组选择标志(RBS0 和 RBS1)确定的寄存器组。通过将偏移量扩展为 16 位正数,来完成加法操作,第 16 位的进位忽略不计。

该寻址方式可对整个存储空间进行。但如果要对一个存储器组寻址(该存储器组没有根据存储器组选择寄存器(BANK)进行设置),则要使用BANK 先对该存储器组进行设置。

### [操作数格式]

| 标识符 | 描述          |
|-----|-------------|
| -   | [HL + byte] |

## [举例]

MOV A, [HL + 10H]; byte 的值为 10H 时





### 3.4.8 基址变址寻址

### [功能]

将 B 或 C 寄存器的内容加到 HL 寄存器中,HL 寄存器作为基地址寄存器,并根据相加结果去寻址。需要访问的 HL、B 和 C 寄存器属于由寄存器组选择标志(RBS0 和 RBS1)确定的寄存器组。通过将 B 或 C 寄存器扩展为一个 16 位的正数来完成加法运算,第 16 位的进位忽略不计。

★ 该寻址方式可对整个存储空间进行。但如果要对一个存储器组寻址 (该存储器组没有根据存储器组选择寄存器 (BANK)进行设置),则要使用 BANK 先对该存储器组进行设置。

### [操作数格式]

| 标识符 | 描述                 |
|-----|--------------------|
| -   | [HL + B], [HL + C] |

### [举例]

以 MOV A, [HL+B]指令为例 (选择 B 寄存器)





## 3.4.9 堆栈寻址

## [功能]

根据堆栈指针(SP)的内容对堆栈区域进行间接寻址。

当执行 PUSH, POP, 子程序调用和返回指令时,或者产生中断请求时保存或恢复寄存器操作时,将自动采用这种寻址方式。

该方式仅对内部高速 RAM 区域进行寻址。

## [举例]

以 PUSH DE 指令为例 (保存在 DE 寄存器中)





## 第四章 存储器组选择功能 (仅用于μPD78F0546, 78F0547 和 78F0547D)

## 4.1 存储器组

通过从 8000H  $\sim$  BFFFH 存储空间选择一个存储器组, $\mu$ PD78F0546、78F0547 和 78F0547D 可以形成一个容量为 96 KB 或 128 KB 的 ROM。

μPD78F0546 有存储器组 0  $\sim$  3,μPD78F0547 和 78F0547D 有存储器组 0  $\sim$  5,如下所示。通过使用存储器组选择寄存器(BANK)选择存储器组。

## 图 4-1 内部 ROM (闪存) 结构

### (a) μPD78F0546



### (b) μPD78F0547, 78F0547D



## 4.2 存储器组选择寄存器 (BANK)

存储器组选择寄存器 (BANK)用于选择要使用的存储器组。

可由8位存储器操作指令设置BANK。

复位信号的产生可将 BANK 清零(00H)。

图 4-2 存储器组选择寄存器 (BANK)的格式

地址: FFF3H 复位后: 00H R/W

| 符号 | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     |
|----|---|---|---|---|---|-------|-------|-------|
| 组  | 0 | 0 | 0 | 0 | 0 | BANK2 | BANK1 | BANK0 |

| BANK2 | BANK1 | BANK0 | 组的设置                       |                               |  |
|-------|-------|-------|----------------------------|-------------------------------|--|
|       |       |       | μPD78F0546                 | μPD78F0547, 78F0547D          |  |
| 0     | 0     | 0     | 公共区域 (32 K) + 存储器组 0 (1    | 16 K)                         |  |
| 0     | 0     | 1     | 公共区域(32 K) + 存储器组 1 (16 K) |                               |  |
| 0     | 1     | 0     | 公共区域(32 K) + 存储器组 2 (16 K) |                               |  |
| 0     | 1     | 1     | 公共区域(32 K) + 存储器组 3 (1     | 6 K)                          |  |
| 1     | 0     | 0     | 禁止设置                       | 公共区域(32 K) + 存储器组 4<br>(16 K) |  |
| 1     | 0     | 1     | 公共区域(32 K) + 存储器组 5 (16 K) |                               |  |
|       | 其它情况  |       | 禁止设置                       |                               |  |

注意事项: 必须修改公共区域 (0000H  $\sim$  7FFFH) BANK 的值。

如果修改了存储器组区域 (8000H  $\sim$  BFFFH) BANK 寄存器的值,则会产生一个预料不到的程序循环。因此不要修改存储器组区域 BANK 寄存器的值。

#### 4.3 选择存储器组

由存储器组选择寄存器(BANK)选择的存储器组被映射到存储器组区域,并可以对其进行访问。因此,如果要访问的存储器组不是当前选择的存储器组,则必须使用 BANK 寄存器选择该存储器组。

不能修改存储器组区域(8000H  $\sim$  BFFFH)的 BANK 寄存器的值。因此,如果要修改存储器组,应执行转移指令,指向公共区域(0000H  $\sim$  7FFFH),并修改该区域中 BANK 的值。

#### 注意事项: 1. 不能获取不同存储器组之间的指令。

- **2.** 在不同存储器组之间不能直接进行转移和访问操作。要在不同存储器组之间执行转移或访问操作,必 须通过公共区域。
- 3. 在公共区域中为中断服务程序分配存储空间。
- 4. 从 7FFFH ~ 8000H 的扩展指令只能在存储器组 0 中执行。

### 4.3.1 存储器组之间的关联值

两个存储器组之间的值不能直接关联。

要从一个存储器组访问另一个存储器组,应进行一次转移操作,指向公共区域(0000H  $\sim$  7FFFH),修改那里的 BANK 设置,然后关联一个值。



• 软件举例 (将一个关联值存于存储器 A 中)

```
RAMD
       DSEG
              SADDR
R_BNKA: DS
              2
                                   ;保护RAM,用于指定关联目的地的一个地址。
R_BNKN: DS
                                   ;保护 RAM,用于指定关联目的地的一个存储器组组号。
              1
R_BNKRN: DS
                                   ;保护 RAM,用于保存关联源的一个存储器组组号。
              1
       MOV
              R_BNKN,#BANKNUM DATA1 ;存储关联目的地的存储器组组号。
       MOVW
              R_BNKA,#DATA1
                                   ;存储关联目的地的地址。
       CALL
              !BNKRD
                                   ;调用用于存储器组之间关联的子程序。
BNKC
       CSEG
                    7000H
BNKRD:
                                   ; 实现存储器组之间关联的子程序。
       PUSH
              \mathsf{HL}
                                   ;保存 HL 寄存器的内容。
       MOV
              A,R_BNKN
              A,BANK
                                   ,
;交换关联源与目的存储器组组号。
       XCH
              R_BNKRN,A
       MOV
                                   ;保存关联源存储器组组号。
       MOVW
              AX,R_BNKA
       XCHW
                                   ,
;指定关联目的地的地址。
              HL,AX
       MOV
              A,[HL]
                                   ;读取目标值。
       XCH
              A,R_BNKRN
                                   ; 获取关联源存储器组组。
              BANK,A
       MOV
                                   ;指定关联源存储器组组号。
              A,R_BNKRN
       MOV
       POP
              HL
                                   ;恢复 HL 寄存器的内容。
       RET
                                   ;返回
DATA
       CSEG
              BANK3
              0AAH
DATA1:
       DB
END
```

备注: 在上述示例中, X 寄存器的值被破坏。

## 4.3.2 存储器组之间的指令转移

存储器组之间不能直接转移指令。

要在存储器组之间转移指令,应先转向公共区域(0000H  $\sim$  7FFFH),修改相关的 BANK 寄存器的设置,然后再执行转移指令。



### • 软件举例

```
RAMD
       DSEG
              SADDR
R_BNKA: DS
              2
                                     ;保护 RAM,用于指定转移目的存储器组的地址。
R_BNKN: DS
                                     ;保护 RAM,用于指定转移目的存储器组的组号。
              1
              R_BNKN,#BANKNUM TEST ;存储 RAM 中转移目的地的存储器组组号。
       MOV
       MOVW
              R_BNKA,#TEST
                                    ;存储 RAM 中转移目的地的地址。
       BR
              !BNKBR
                                    ;转向中间存储器组转移处理。
BNKC
       CSEG
              \mathsf{AT}
                     7000H
BNKBR:
       MOV
              A,R_BNKN
       MOV
              BANK,A
                                     ;指定转移目的地的存储器组组号。
       MOVW
              AX,R_BNKA
                                     ; 指定转移目的地的地址。
       BR
              \mathsf{AX}
                                     ;转移。
BN3
TEST:
       CSEG
              BANK3
       MOV ...
END
```

备注: 在上述软件示例中, AX 寄存器的值被破坏。

### 4.3.3 存储器组之间的子程序调用

存储器组之间不能直接调用子程序。

要在存储器组之间调用子程序,应先转向公共区域(0000H  $\sim$  7FFFH),通过使用相关的 BANK 寄存器指定调用目的 地的存储器组,然后执行 CALL 指令,通过该指令转向调用目的地。

此时将 BANK 的当前值存入 RAM。在执行 RET 指令前恢复 BANK 的值。



#### • 软件举例

```
SADDR
RAMD
       DSEG
                                     ;保护 RAM,用于指定调用目的地的地址。
R_BNKA: DS
               2
R_BNKN: DS
                                     ;保护 RAM,用于指定调用目的地的存储器组组号。
               1
R_BNKRN: DS
                                     ;保护 RAM,用于保存调用源的存储器组组号。
               1
       MOV
               R_BNKN,#BANKNUM TEST
                                     ;存储 RAM 中调用目的地的存储器组组号。
       MOVW
                                     ;存储 RAM 中调用目的地的地址。
               R_BNKA,#TEST
               !BNKCAL
                                     ;转向中间存储器组调用处理程序。
       CALL
BNKC
        CSEG
               \mathsf{AT}
                      7000H
BNKCAL:
                                     ;中间存储器组调用处理程序。
        MOV
               \mathsf{A}, \mathsf{R}\_\mathsf{BNKN}
                                     ; 获取调用目的地的存储器组组号。
       XCH
               A,BANK
                                     ;修改该存储器组,并获取调用源的存储器组组号。
       MOV
               R_BNKRN,A
                                     ;将调用源的存储器组组号存于 RAM 中。
       CALL
               !BNKCALS
                                     ;调用子程序转向调用目的地。
       XCH
               A,R BNKRN
       MOV
               BANK,A
                                     ;指定调用源的存储器组组号。
       RET
                                     ;返回调用源。
BNKCALS:
       MOVW
              AX,R_BNKA
                                     ; 指定调用目的地的地址。
       BR
               \mathsf{AX}
                                     ;转向调用目的地。
BN3
       CSEG
               BANK3
TEST:
       MOV ···
       RET
END
```

备注: 在上述软件示例中, AX 寄存器的值被破坏。不支持复用处理。

### 4.3.4 通过中断将指令转向存储器组区域

当中断产生时,通过使用向量表,指令可以转向由 BANK 指定的存储器组,但当中断产生时很难识别 BANK 寄存器。

因此,通过公共区域(0000H ~ 7FFFH)的向量表指定转移目的地的地址,通过使用公共区域中的 BANK 寄存器指定转移目的地的存储器组,并执行 CALL 指令。此时在修改 RAM 之前保存 BANK 寄存器的内容,并在执行 RETI 指令前恢复 BANK 的值。

**备注:** 在公共区域为要求快速响应的中断服务程序分配存储空间。



• 软件举例 (当使用 16 位定时器/事件计数器 00 的中断请求时)

| VCTBL           | CSEG<br>DW                              | AT 0020H<br>BNKITM000                                                     | ;指定定时器中断目的地的地址。                                                              |  |  |
|-----------------|-----------------------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------|--|--|
| RAMD<br>R_BNKRN | DSEG<br>N: DS                           | SADDR<br>1                                                                | ;保护 RAM,用于在中断产生前保存存储器组组号。                                                    |  |  |
| BNKC            | CSEG                                    | AT 7000H                                                                  |                                                                              |  |  |
| BNKITM0         | 00:<br>PUSH                             | AX                                                                        | ;中间存储器组中断服务程序。<br>;保存 AX 寄存器的内容。                                             |  |  |
|                 | MOV<br>MOV<br>MOV<br>CALL<br>MOV<br>MOV | A,BANK<br>R_BNKRN,A<br>BANK,#BANKNUM TEST<br>!TEST<br>A,R_BNKRN<br>BANK,A | ;在中断产生前将存储器组组号保存于 RAM 中。<br>;指定中断程序的存储器组组号。<br>;调用该中断程序。<br>;恢复中断产生前的存储器组组号。 |  |  |
|                 | POP                                     | AX                                                                        | ;恢复 AX 寄存器的内容。                                                               |  |  |
|                 | RETI                                    |                                                                           |                                                                              |  |  |
| BN3<br>TEST:    | CSEG<br>MOV ···<br>:                    | BANK3                                                                     | ;中断服务程序。                                                                     |  |  |
| END             | RET                                     |                                                                           |                                                                              |  |  |

**备注:** 注意以下几点,以便有效使用存储器组选择功能。

- 在公共区域中为经常使用的程序分配存储空间。
- 如果一个需要被关联的值存于 RAM 中,则该值可以与所有存储区域关联。
- 如果存于一个存储器组中的程序的关联目的地与转移目的地是在同一个存储器组中,则代码长度可以减少且处理更有效。
- 在公共区域中为需要快速响应的中断服务程序分配存储空间。

## 第五章 端口功能

## 5.1 端口功能

有三种类型的引脚 I/O 缓冲电源: AVREF, EVDD, 和 VDD。这些电源和引脚之间的关系显示如下。

\*

表 5-1 引脚 I/O 缓冲电源

| 电源               | 相关引脚                           |
|------------------|--------------------------------|
| AVREF            | P20~P27                        |
| EV <sub>DD</sub> | 端口引脚(P20 ~ P27、P121 ~ P124 除外) |
| V <sub>DD</sub>  | ● P121 ~ P124<br>● 非端口引脚       |

78K0/KF2 产品中提供的端口如图 5-1 所示,这些端口可以支持多种控制操作。每个端口的功能如表 5-2 所示。 除了作为数字 I/O 端口功能,这些端口还有几个复用功能。如需了解这些端口复用功能的详细信息,请参见**第二章 引脚功能。** 

图 5-1 端口类型



## 表 5-2 端口功能 (1/2)

| 功能名称      | I/O | 功能                                                       | 复位后  | 复用功能                      |
|-----------|-----|----------------------------------------------------------|------|---------------------------|
| P00       | I/O | 端口 0                                                     | 输入端口 | T1000                     |
| P01       |     | 7位 I/O 端口                                                |      | TI010/TO00                |
| P02       |     | 可以位选输入输出模式<br>通过软件设置,可以定义内部上拉电阻的使用                       |      | SO11                      |
| P03       |     | 是是我们交通,可要是人们带上还是面前使用                                     |      | SI11                      |
| P04       |     |                                                          |      | SCK11                     |
| P05       |     |                                                          |      | TI001/SSI11               |
| P06       |     |                                                          |      | TI011/TO01                |
| P10       | I/O | 端口 1                                                     | 输入端口 | SCK10/TxD0                |
| P11       |     | 8位 I/O端口                                                 |      | SI10/RxD0                 |
| P12       |     | 可以位选输入输出模式<br>通过软件设置,可以定义内部上拉电阻的使用                       |      | SO10                      |
| P13       |     | ZZWITKE, TSZZZITELE                                      |      | TxD6                      |
| P14       |     |                                                          |      | RxD6                      |
| P15       |     |                                                          |      | ТОН0                      |
| P16       |     |                                                          |      | TOH1/INTP5                |
| P17       |     |                                                          |      | TI50/TO50                 |
| P20 ∼ P27 | I/O | 端口 2<br>8位 I/O 端口<br>可以位选输入输出模式                          | 输入端口 | ANIO ~ ANI7               |
| P30       | I/O | 端口3                                                      | 模拟输入 | INTP1                     |
| P31       |     | 4位 I/O 端口                                                |      | INTP2/OCD1A **            |
| P32       |     | 可以位选输入输出模式 通过软件设置,可以定义内部上拉电阻的使用                          |      | INTP3/OCD1B <sup>26</sup> |
| P33       |     | 是是我们改造,可以是人们能上述"品面的"(A)                                  |      | TI51/TO51/INTP4           |
| P40 ~ P47 | I/O | 端口 4<br>8 位 I/O 端口<br>可以位选输入输出模式<br>通过软件设置,可以定义内部上拉电阻的使用 | 输入端口 | -                         |
| P50 ~ P57 | I/O | 端口 5<br>8 位 I/O 端口<br>可以位选输入输出模式<br>通过软件设置,可以定义内部上拉电阻的使用 | 输入端口 | -                         |
| P60       | I/O | 端口 6                                                     | 输入端口 | SCL0                      |
| P61       |     | 8位 I/O端口                                                 |      | SDA0                      |
| P62       |     | P60~P63的输出是 N-ch 漏极开路输出(6 V 耐压) 可以位选输入输出模式               |      | EXSCL0                    |
| P63 ~ P67 |     | 只有 P64~P67,可以通过软件设置,定义内部上拉电阻的使用                          |      |                           |
| P70 ~ P77 | I/O | 端口 7<br>8 位 I/O 端口<br>可以位选输入输出模式<br>通过软件设置,可以定义内部上拉电阻的使用 | 输入端口 | KR0 ∼ KR7                 |

# **注:** 仅用于μPD78F0547D

表 5-2 端口功能 (2/2)

| 功能名称 | I/O | 功能                                         | 复位后  | 复用功能              |
|------|-----|--------------------------------------------|------|-------------------|
| P120 | I/O | 端口 12                                      | 输入端口 | INTP0/EXLVI       |
| P121 |     | 5位 1/0 端口                                  |      | X1/OCD0A **       |
| P122 |     | 可以位选输入输出模式<br>只有 P120,可以通过软件设置,定义内部上拉电阻的使用 |      | X2/EXCLK/OCD0B ** |
| P123 |     | 7 TO TORREST VENT OF THE BEAUTY OF         |      | XT1               |
| P124 |     |                                            |      | XT2/EXCLKS        |
| P130 | 输出  | 端口 13<br>1 位仅输出端口                          | 输出端口 | -                 |
| P140 | I/O | 端口 14                                      | 输入端口 | PCL/INTP6         |
| P141 |     | 6位 I/O 端口                                  |      | BUZ/BUSY0/INTP7   |
| P142 |     | 可以位选输入输出模式<br>通过软件设置,可以定义内部上拉电阻的使用         |      | SCKA0             |
| P143 |     |                                            |      | SIA0              |
| P144 |     |                                            |      | SOA0              |
| P145 |     |                                            |      | STB0              |

**注:** 仅用于μPD78F0547D

# 5.2 端口设置

端口包括如下硬件。

表 5-3 端口配置

|       | the complete                                                                                                                   |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 项目    | 设置                                                                                                                             |
| 控制寄存器 | 端口模式寄存器 (PM0~ PM7, PM12, PM14)<br>端口寄存器 (P0~ P7, P12~ P14)<br>上拉电阻选择寄存器 (PU0, PU1, PU3 ~ PU7, PU12, PU14)<br>A/D端口配置寄存器 (ADPC) |
| 端口    | 总数: 71 (CMOS I/O: 66, CMOS 输出: 1, N-ch 漏极开路 I/O: 4)                                                                            |
| 上拉电阻  | 总数: 54                                                                                                                         |

#### 5.2.1 端口 0

端口 0 是具有输出锁存功能的 7 位 I/O 端口。通过使用端口模式寄存器 0(PM0),可以位选端口 0 为输入或输出模式。如果 P00 ~ P06 作为输入端口,则内部上拉电阻的使用可以通过上拉电阻选择寄存器 0(PU0)以 1 位单元的方式指定。

这个端口还可以用于定时器 I/O、串行接口数据 I/O、时钟 I/O 和芯片选择输入。

复位信号的产生可将端口0设置为输入模式。

图 5-2 ~到 5-5 显示端口 0 的框图。

★ 注意事项: 如果 P02/SO11 和 P04/SCK11 作为通用端口使用,则将串行操作模式寄存器 11(CSIM11)和串行时钟选择寄存器 11(CSIC11)设置为默认状态(00H)。



图 5-2 P00、P03 和 P05 的框图

P0: 端口寄存器 0

PU0: 上拉电阻选择寄存器 0 PM0: 端口模式寄存器 0

图 5-3 P01 和 P06 的框图



P0: 端口寄存器 0

PU0: 上拉电阻选择寄存器 0 PM0: 端口模式寄存器 0

图 5-4 P02 的框图



P0: 端口寄存器 0

PU0: 上拉电阻选择寄存器 0 PM0: 端口模式寄存器 0

图 5-5 P04 的框图



P0: 端口寄存器 0

PU0: 上拉电阻选择寄存器 0 PM0: 端口模式寄存器 0

#### 5.2.2 端口 1

端口 1 是具有输出锁存功能的 8 位 I/O 端口。通过使用端口模式寄存器 1(PM1),可以位选端口 1 为输入或输出模式。如果 P10 ~ P17 作为输入端口,则内部上拉电阻的使用可以通过上拉电阻选择寄存器 1(PU1)以 1 位单元的方式指定。

这个端口还可以用于外部中断请求输入、串行接口数据 I/O、时钟 I/O 和定时器 I/O。

复位信号的产生可将端口1设置为输入模式。

图 5-6  $\sim$  5-10 显示端口 1 的框图。

注意事项: 如果 P10/SCK10/TxD0 和 P12/SO10 作为通用端口使用,则将串行操作模式寄存器 10(CSIM10)和串行时钟选择寄存器 10(CSIC10)设置为默认状态(00H)。

EVDD  $WR_{\text{PU}}$ PU1 PU10 P-ch 复用功能 RD 盤 选择器 内部总线 WRPORT P1 输出锁存器 - P10/SCK10/TxD0 (P10)  $WR_{\text{PM}}$ PM1 PM10 复用功能

图 5-6 P10 的框图

P1: 端口寄存器 1

PU1: 上拉电阻选择寄存器 1 PM1: 端口模式寄存器 1

## 图 5-7 P11 和 P14 的框图



P1: 端口寄存器 1

PU1: 上拉电阻选择寄存器 1 PM1: 端口模式寄存器 1

## 图 5-8 P12 和 P15 的框图



P1: 端口寄存器 1

PU1: 上拉电阻选择寄存器 1 PM1: 端口模式寄存器 1

图 5-9 P13 的框图



P1: 端口寄存器 1

PU1: 上拉电阻选择寄存器 1 PM1: 端口模式寄存器 1

图 5-10 P16 和 P17 的框图



P1: 端口寄存器 1

PU1: 上拉电阻选择寄存器 1 PM1: 端口模式寄存器 1

#### 5.2.3 端口 2

端口 2 是具有输出锁存功能的 8 位 I/O 端口。通过使用端口模式寄存器 2(PM2),可以位选端口 2 为输入或输出模式。

这个端口还可以用于 A/D 转换器模拟输入。

★ 如果要将 P20/ANIO ~ P27/ANI7 作为数字输入引脚,应通过使用 A/D 端口配置寄存器(ADPC)将这些引脚设置为数字 I/O 模式,并通过使用 PM2 设置为输入模式。从低位开始使用这些引脚。

如果要将 P20/ANIO  $\sim$  P27/ANI7 作为数字输出引脚,应通过使用 A/D 端口配置寄存器(ADPC)将这些引脚设置为数字 I/O 模式,并通过使用 PM2 设置为输出模式。

| 表 5-4  | P20/ANI0~   | P27/ANI7 引  | 脚的功能设置 |
|--------|-------------|-------------|--------|
| 4X J-4 | FZU/AINIU ~ | FZIIANII 71 |        |

| ADPC      | PM2  | ADS     | P20/ANI0 ~ P27/ANI7 引脚 |
|-----------|------|---------|------------------------|
| 数字 I/O 选择 | 输入模式 | 选择 ANI. | 禁止设置                   |
|           |      | 不选 ANI. | 数字输入                   |
|           | 输出模式 | 选择 ANI. | 禁止设置                   |
|           |      | 不选 ANI. | 数字输出                   |
| 模拟输入选择    | 输入模式 | 选择 ANI. | 模拟输入(被转换)              |
|           |      | 不选 ANI. | 模拟输入(不被转换)             |
|           | 输出模式 | 选择 ANI. | 禁止设置                   |
|           |      | 不选 ANI. |                        |

在复位信号的产生时,P20/ANI0  $\sim$  P27/ANI7 都被设置为模拟输入模式。图 5-11 显示了端口 2 的框图.

图 5-11 P20 ~ P27 的框图

P2: 端口寄存器 2 PM2: 端口模式寄存器 2

#### 5.2.4 端口3

端口 3 是具有输出锁存功能的 4 位 I/O 端口。通过使用端口模式寄存器 3(PM3),可以位选端口 3 为输入或输出模式。如果 P30 ~ P33 作为输入端口,则内部上拉电阻的使用可以通过上拉电阻选择寄存器 3(PU3)以 1 位单元的方式指定。

这个端口还可以用于外部中断请求输入和定时器 I/O。

复位信号的产生可将端口3设置为输入模式。

图 5-12 ~ 5-13 显示端口 3 的框图。

## 注意事项: 在<sub>4</sub>PD78F0547D 中, 为了避免误操作,复位后必须下拉 P31。

**备注:** 若要使用片上调试功能,可以通过 $\mu$ PD78F0547D 的 P31 和 P32 引脚进行设置(OCD1A, OCD1B)。详细信息可参见**第二十八章 片上调试功能(仅用于\muPD78F0547D)**。



图 5-12 P30~P32 的框图

P3: 端口寄存器 3

PU3: 上拉电阻选择寄存器 3 PM3: 端口模式寄存器 3

RD: 读信号 WR××: 写信号

**注:** 仅用于μPD78F0547D

图 5-13 P33 的框图



P3: 端口寄存器 3

PU3: 上拉电阻选择寄存器 3 PM3: 端口模式寄存器 3

### 5.2.5 端口 4

端口 4 是具有输出锁存功能的 8 位 I/O 端口。通过使用端口模式寄存器 4(PM4),可以位选端口 4 为输入或输出模式。如果 P40 ~ P47 作为输入端口,则内部上拉电阻的使用可以通过上拉电阻选择寄存器 4(PU4)以 1 位单元的方式指定。

复位信号的产生可将端口4设置为输入模式。

图 5-14 显示端口 4 的框图。

图 5-14 P40~ P47 的框图



P4: 端口寄存器 4

PU4: 上拉电阻选择寄存器 4

PM4: 端口模式寄存器 4

### 5.2.6 端口 5

端口 5 是具有输出锁存功能的 8 位 I/O 端口。通过使用端口模式寄存器 5(PM5),可以位选端口 5 为输入或输出模式。当 P50 ~ P57 作为输入端口时,内部上拉电阻的使用可以通过上拉电阻选择寄存器 5(PU5)以 1 位单元的方式指定。

复位信号的产生可将端口5设置为输入模式。

图 5-15 显示端口 5 的框图。

图 5-15 P50~P57 的框图



P5: 端口寄存器 5

PU5: 上拉电阻选择寄存器 5 PM5: 端口模式寄存器 5

#### 5.2.7 端口 6

端口 6 是具有输出锁存功能的 8 位 I/O 端口。通过使用端口模式寄存器 6(PM6),可以位选端口 6 为输入或输出模式。当 P64 ~ P67 作为输入端口时,内部上拉电阻的使用可以通过上拉电阻选择寄存器 6(PU6)以 1 位单元的方式指定。

P60  $\sim$  P63 引脚的输出是 N-ch 漏极开路输出(6V 耐压)。

这个端口还可以用于串行接口数据 I/O、时钟 I/O 和外部时钟输入。

复位信号的产生可将端口6设置为输入模式。

图 5-16 ~ 5-19 显示端口 6 的框图。

备注: 在使用 P62/EXSCL0 作为串行接口外部时钟输入引脚时,应输入一个 6.4 MHz 的时钟。



图 5-16 P60 和 P61 的框图

P6: 端口寄存器 6 PM6: 端口模式寄存器 6

图 5-17 P62 的框图



P6: 端口寄存器 6 PM6: 端口模式寄存器 6

RD: 读信号 WR××: 写信号

图 5-18 P63 的框图



P6: 端口寄存器 6 PM6: 端口模式寄存器 6

×

图 5-19 P64~P67 的框图



P6: 端口寄存器 6 PM6: 端口模式寄存器 6

### 5.2.8 端口 7

端口 7 是具有输出锁存功能的 8 位 I/O 端口。通过使用端口模式寄存器 7(PM7),可以位选端口 7 为输入或输出模式。当 P70 ~ P77 作为输入端口时,内部上拉电阻的使用可以通过上拉电阻选择寄存器 7(PU7)以 1 位单元的方式指定。

这个端口还可以用作按键返回输入。

复位信号的产生可将端口7设置为输入模式。

图 5-20 显示端口 7 的框图。

图 5-20 P70 ~P77 的框图



P7: 端口寄存器 7

PU4: 上拉电阻选择寄存器 7 PM7: 端口模式寄存器 7

#### 5.2.9 端口 12

端口 12 是具有输出锁存功能的 5 位 I/O 端口。通过使用端口模式寄存器 12(PM12),可以位选端口 12 为输入或输出模式。当 P120 只用作输入端口时,内部上拉电阻的使用可以通过上拉电阻选择寄存器 12(PU12)指定。

这个端口还可以用于外部中断请求输入、外部低电压检测的电压输入、主系统时钟振荡器的连接、子系统时钟振荡器的连接、主系统时钟的外部时钟输入和子系统时钟的外部时钟输入。

复位信号的产生可将端口 12 设置为输入模式。

图 5-21 和 5-22 显示端口 12 的框图。

注意事项: 当使用 P121 ~ P124 引脚连接主系统时钟(X1,X2)或子系统时钟(XT1,XT2)的振荡器,或者输入该主系统时钟的外部时钟(EXCLK)或子系统时钟的外部时钟(EXCLKS)时,必须通过使用时钟操作模式选择寄存器(OSCCTL)对 X1 振荡模式、XT1 振荡模式或者外部时钟输入模式进行设置(如需了解详细信息,可参见 6.3 (1) 时钟操作模式选择寄存器(OSCCTL)和(3)子系统时钟引脚操作模式设置)。OSCCTL 的复位值为 00H(P121 ~ P124 都用作 I/O 端口引脚)。在这种情况下,不必对 PM121 ~ PM124 和 P121 ~ P124 引脚进行设置。

**备注:** 若要使用片上调试功能,可以通过μPD78F0547D 的 X1 和 X2 引脚进行设置(OCD0A, OCD0B)。详细信息可参见**第二十八章 片上调试功能(仅用于μPD78F0547D)**。





P12: 端口寄存器 12

PU12: 上拉电阻选择寄存器 12

PM12: 端口模式寄存器 12

 $\star$ 

图 5-22 P121 ~ P124 的框图



P12: 端口寄存器 12

PU12: 上拉电阻选择寄存器 12 PM12: 端口模式寄存器 12 OSCCTL: 时钟操作模式选择寄存器

RD: 读信号 WR××: 写信号

## **注:** 仅用于μPD78F0547D

# 5.2.10 端口 13

端口 13 是 1 位仅输出端口。 图 5-23 显示了端口 13 的框图。

图 5-23 P130 的框图



P13: 端口寄存器 13

RD: 读信号 WR××: 写信号

**备注** 当复位信号有效时,P130 输出低电平。如果在复位信号有效前将P130 设置为高电平输出,则P130 的输出信号可以作为虚拟的CPU复位信号。



\*

#### 5.2.11 端口 14

端口 14 是具有输出锁存功能的 6 位 I/O 端口。通过使用端口模式寄存器 14(PM14),可以位选端口 14 为输入或输出模式。当 P140 ~ P145 作为输入端口时,内部上拉电阻的使用可以通过上拉电阻选择寄存器 14(PU14)以 1 位单元的方式指定。

这个端口还可以用于外部中断请求输入、蜂鸣器输出、时钟输出、串行接口数据 I/O、时钟 I/O、忙输入和选通输出。

复位信号的产生可将端口 14 设置为输入模式。

图 5-24 ~ 5-27 显示端口 14 的框图。

图 5-24 P140 和 P141 的框图



P14: 端口寄存器 14

PU14: 上拉电阻选择寄存器 14 PM14: 端口模式寄存器 14

图 5-25 P142 的框图



P14: 端口寄存器 14

PU14: 上拉电阻选择寄存器 14 PM14: 端口模式寄存器 14

# 图 5-26 P143 的框图



P14: 端口寄存器 14

PU14: 上拉电阻选择寄存器 14 PM14: 端口模式寄存器 14

图 5-27 P144 和 P145 的框图



P14: 端口寄存器 14

PU14: 上拉电阻选择寄存器 14 PM14: 端口模式寄存器 14

## 5.3 控制端口功能的寄存器

端口功能由如下四种类型寄存器控制。

- 端口模式寄存器 (PM0 ~ PM7, PM12, PM14)
- 端口寄存器 (P0 ~ P7, P12 ~ P14)
- 上拉电阻选择寄存器(PU0, PU1, PU3 ~ PU7, PU12, PU14)
- A/D 端口配置寄存器 (ADPC)

## (1) 端口模式寄存器(PM0~PM7, PM12和PM14)

这类寄存器以1位单元的方式定义端口的输入或输出模式。

可以由1位或8位存储器操作指令设置这些寄存器。

复位信号的产生可将这些寄存器的内容设置为 FFH。

当端口引脚使用复用功能时,需要参考 **5.5 使用复用功能时端口模式寄存器和输出锁存器的设置**,对端口模式寄存器进行设置。

# 图 5-28 端口模式寄存器的格式

| 符号   | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     | 地址    | 复位后 | R/W |
|------|------|------|-------|-------|-------|-------|-------|-------|-------|-----|-----|
| PM0  | 1    | PM06 | PM05  | PM04  | PM03  | PM02  | PM01  | PM00  | FF20H | FFH | R/W |
|      |      |      |       |       |       |       |       |       |       |     |     |
| PM1  | PM17 | PM16 | PM15  | PM14  | PM13  | PM12  | PM11  | PM10  | FF21H | FFH | R/W |
|      |      |      |       |       |       |       |       |       |       |     |     |
| PM2  | PM27 | PM26 | PM25  | PM24  | PM23  | PM22  | PM21  | PM20  | FF22H | FFH | R/W |
|      |      |      |       |       |       |       |       |       |       |     |     |
| РМ3  | 1    | 1    | 1     | 1     | PM33  | PM32  | PM31  | PM30  | FF23H | FFH | R/W |
|      |      |      |       |       |       |       |       |       |       |     |     |
| PM4  | PM47 | PM46 | PM45  | PM44  | PM43  | PM42  | PM41  | PM40  | FF24H | FFH | R/W |
|      |      |      |       |       |       |       |       |       |       |     |     |
| PM5  | PM57 | PM56 | PM55  | PM54  | PM53  | PM52  | PM51  | PM50  | FF25H | FFH | R/W |
|      |      |      |       |       |       |       |       |       |       |     |     |
| PM6  | PM67 | PM66 | PM65  | PM64  | PM63  | PM62  | PM61  | PM60  | FF26H | FFH | R/W |
|      |      |      |       |       |       |       |       |       |       |     |     |
| PM7  | PM77 | PM76 | PM75  | PM74  | PM73  | PM72  | PM71  | PM70  | FF27H | FFH | R/W |
|      |      | '    |       |       |       |       |       |       |       |     |     |
| PM12 | 1    | 1    | 1     | PM124 | PM123 | PM122 | PM121 | PM120 | FF2CH | FFH | R/W |
|      |      | •    |       |       |       | •     |       |       |       |     |     |
| PM14 | 1    | 1    | PM145 | PM144 | PM143 | PM142 | PM141 | PM140 | FF2EH | FFH | R/W |
|      |      | 1    | 1     | 1     |       | 1     | 1     |       |       |     |     |

| PMmn | Pmn 引脚 I/O 模式选择                        |  |  |  |  |  |  |
|------|----------------------------------------|--|--|--|--|--|--|
|      | $(m = 0 \sim 7, 12, 14; n = 0 \sim 7)$ |  |  |  |  |  |  |
| 0    | 输出模式 (输出缓冲器打开)                         |  |  |  |  |  |  |
| 1    | 输入模式 (输出缓冲器关闭)                         |  |  |  |  |  |  |

# (2) 端口寄存器 (P0 到 P7, P12 到 P14)

这类寄存器用于设置芯片端口要输出的数据。

如果在输入模式下读端口,则读取的是引脚电平。如果在输出模式下读端口,则读取的是输出锁存器的值。可以由 1 位或 8 位存储器操作指令设置这些寄存器。

复位信号的产生可将寄存器清零(00H)。

# 图 5-29 端口寄存器的格式

| 符号  | 7                                            | 6    | 5             | 4    | 3    | 2    |   | 1   | 0    | 地址                              | 复位后                | R/W   |  |  |  |  |
|-----|----------------------------------------------|------|---------------|------|------|------|---|-----|------|---------------------------------|--------------------|-------|--|--|--|--|
| P0  | 0                                            | P06  | P05           | P04  | P03  | P02  | F | 201 | P00  | FF00H                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
|     |                                              |      |               |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P1  | P17                                          | P16  | P15           | P14  | P13  | P12  | F | P11 | P10  | FF01H                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
|     |                                              |      |               |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P2  | P27                                          | P26  | P25           | P24  | P23  | P22  | P | 21  | P20  | FF02H                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
|     |                                              |      |               |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P3  | 0                                            | 0    | 0             | 0    | P33  | P32  | F | 231 | P30  | FF03H                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
|     |                                              |      |               |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P4  | P47                                          | P46  | P45           | P44  | P43  | P42  | P | P41 | P40  | FF04H                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
|     |                                              |      |               |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P5  | P57                                          | P56  | P55           | P54  | P53  | P52  | F | P51 | P50  | FF05H                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
|     |                                              |      |               |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P6  | P67                                          | P66  | P65           | P64  | P63  | P62  | F | P61 | P60  | FF06H                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
| ,   |                                              |      |               |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P7  | P77                                          | P76  | P75           | P74  | P73  | P72  | F | 71  | P70  | FF07H                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
| ,   |                                              | •    |               |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P12 | 0                                            | 0    | 0             | P124 | P123 | P122 | Р | 121 | P120 | FF0CH                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
| ,   |                                              | •    | •             |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P13 | 0                                            | 0    | 0             | 0    | 0    | 0    |   | 0   | P130 | FF0DH                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
| '   |                                              |      |               | 1.   |      |      |   |     |      |                                 |                    |       |  |  |  |  |
| P14 | 0                                            | 0    | P145          | P144 | P143 | P142 | Р | 141 | P140 | FF0EH                           | 00H(输出锁存器)         | R/W   |  |  |  |  |
|     |                                              | 1    | ı             |      |      | ı    |   |     |      |                                 | 001 (III) EI (III) |       |  |  |  |  |
|     | Pmn $m = 0 \sim 7, 12 \sim 14; n = 0 \sim 7$ |      |               |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
|     |                                              |      | 输出数据控制(输出模式下) |      |      |      |   |     |      |                                 |                    |       |  |  |  |  |
|     | 0                                            | 输出 0 | ` '           |      |      |      |   |     | 低电平  | A SAME OF IN ( IIIA) A DOCA ( ) |                    |       |  |  |  |  |
|     | 1                                            | 输出 1 |               |      |      |      |   |     | 高电平  |                                 |                    | 输入高电平 |  |  |  |  |

## (3) 上拉电阻选择寄存器 (PU0, PU1, PU3 ~ PU7, PU12 和 PU14)

这类寄存器指定是否使用 P00  $\sim$  P60、P10  $\sim$  P17、P30  $\sim$  P33、P40  $\sim$  P47、P50  $\sim$  P57、P60  $\sim$  P67、P70  $\sim$  P77、P120 或 P140  $\sim$  P145 的内部上拉电阻。内部上拉电阻可以以 1 位单元的方式用于那些已设置为输入模式的引脚,并且这些引脚已通过 PU0、PU1、 PU3  $\sim$  PU7、PU12 和 PU14 指定为使用内部上拉电阻。不论是否设置了 PU0、 PU1、PU3  $\sim$  PU7、PU12 和 PU14,设置为输出模式的引脚和用作复用功能的输出引脚都不连接内部上拉电阻。

可以由1位或8位存储器操作指令设置这些寄存器。

连接内部上拉电阻

复位信号的产生可将这些寄存器清零(00H)。

图 5-30 上拉电阻选择寄存器的格式

| 符号   | 7    | 6    | 5                | 4     | 3     | 2                | 1          | 0                | 地址    | 复位后 | R/W |
|------|------|------|------------------|-------|-------|------------------|------------|------------------|-------|-----|-----|
| PU0  | 0    | PU06 | PU05             | PU04  | PU03  | PU02             | PU01       | PU00             | FF30H | 00H | R/W |
|      |      |      |                  |       |       |                  |            |                  | •     |     |     |
| PU1  | PU17 | PU16 | PU15             | PU14  | PU13  | PU12             | PU11       | PU10             | FF31H | 00H | R/W |
|      |      |      |                  |       |       |                  |            |                  |       |     |     |
| PU3  | 0    | 0    | 0                | 0     | PU33  | PU32             | PU31       | PU30             | FF33H | 00H | R/W |
|      |      |      |                  |       |       |                  |            |                  |       |     |     |
| PU4  | PU47 | PU46 | PU45             | PU44  | PU43  | PU42             | PU41       | PU40             | FF34H | 00H | R/W |
|      |      |      |                  |       |       |                  |            |                  |       |     |     |
| PU5  | PU57 | PU56 | PU55             | PU54  | PU53  | PU52             | PU51       | PU50             | FF35H | 00H | R/W |
|      |      |      |                  |       |       |                  |            |                  | ı     |     |     |
| PU6  | PU67 | PU66 | PU65             | PU64  | 0     | 0                | 0          | 0                | FF36H | 00H | R/W |
|      |      |      |                  |       |       |                  |            | -                | 1     |     |     |
| PU7  | PU77 | PU76 | PU75             | PU74  | PU73  | PU72             | PU71       | PU70             | FF37H | 00H | R/W |
|      |      |      |                  |       |       |                  |            |                  | ı     |     |     |
| PU12 | 0    | 0    | 0                | 0     | 0     | 0                | 0          | PU120            | FF3CH | 00H | R/W |
|      |      |      |                  |       |       |                  |            |                  | ı     |     |     |
| PU14 | 0    | 0    | PU145            | PU144 | PU143 | PU142            | PU141      | PU140            | FF3EH | 00H | R/W |
|      |      |      |                  |       |       |                  |            |                  | 1     |     |     |
|      | PUmn |      |                  |       |       | Pmn 引脚内          |            | 阻选择              |       |     |     |
|      |      |      |                  |       | (m =  | = 0, 1, 3 $\sim$ | 7, 12, 14; | $n = 0 \sim 7$ ) | 1     |     |     |
| ľ    | 0    | 不连接内 | <b>不连接内部上拉电阻</b> |       |       |                  |            |                  |       |     |     |

## ★ (4) A/D 端口配置寄存器 (ADPC)

这个寄存器将 P20/ANI0 ~ P27/ANI7 引脚切换为数字 I/O 端口 或 A/D 转换器的模拟输入。可由 1 位或者 8 位存储器操作指令对 ADPC 进行设置。 复位信号的产生可将寄存器清零(00H)。

图 5-31 A/D 端口配置寄存器的格式 (ADPC)

| 地址   | FF2FH | 复位后 | 00H R/W |   |       |       |       |       |
|------|-------|-----|---------|---|-------|-------|-------|-------|
| 符号   | 7     | 6   | 5       | 4 | 3     | 2     | 1     | 0     |
| ADPC | 0     | 0   | 0       | 0 | ADPC3 | ADPC2 | ADPC1 | ADPC0 |

| ADPC3 | ADPC2 | ADPC1 | ADPC0 |              | 数字 I/O(D)/模拟输入(A)切换 |    |              |   |              |   |              |
|-------|-------|-------|-------|--------------|---------------------|----|--------------|---|--------------|---|--------------|
|       |       |       |       | P27/<br>ANI7 | P26/<br>ANI6        |    | P24/<br>ANI4 |   | P22/<br>ANI2 | l | P20/<br>ANI0 |
| 0     | 0     | 0     | 0     | Α            | Α                   | Α  | Α            | Α | Α            | Α | Α            |
| 0     | 0     | 0     | 1     | Α            | Α                   | Α  | Α            | Α | Α            | Α | D            |
| 0     | 0     | 1     | 0     | Α            | Α                   | Α  | Α            | Α | Α            | D | D            |
| 0     | 0     | 1     | 1     | Α            | Α                   | Α  | Α            | Α | D            | D | D            |
| 0     | 1     | 0     | 0     | Α            | Α                   | Α  | Α            | D | D            | D | D            |
| 0     | 1     | 0     | 1     | Α            | Α                   | Α  | D            | D | D            | D | D            |
| 0     | 1     | 1     | 0     | Α            | Α                   | D  | D            | D | D            | D | D            |
| 0     | 1     | 1     | 1     | Α            | D                   | D  | D            | D | D            | D | D            |
| 1     | 0     | 0     | 0     | D            | D                   | D  | D            | D | D            | D | D            |
|       | 其它情况  |       |       |              | 禁止说                 | 设置 |              |   |              |   |              |

注意事项: 1. 通过使用端口模式寄存器 2(PM2)将 A/D 转换通道设置为输入模式。

- 2. 在使用模拟输入通道选择寄存器(ADS)时,不要通过 ADPC 将引脚设置为数字 I/O 引脚。
- 3. 如果将数据写入 ADPC,则产生一个等待周期。当 CPU 使用子系统时钟并且外部硬件时钟停止时,不要将数据写入 ADPC。详细情况可参见 第三十二章 等待注意事项。

#### 5.4 端口功能操作

对输入模式和输出模式的端口操作是不同的,具体如下所示。

注意事项: 在使用 1 位存储器操作指令的情况下,虽然操作的是 1 位,但仍以 8 位的操作形式访问端口。因此,对于一个既有输入引脚又有输出引脚的端口,所有定义为输入引脚的输出锁存器的内容是不确定的,而那些未被操作的位也是如此。

#### 5.4.1 写入 I/O 端口

#### (1) 输出模式

使用传送指令对输出锁存器进行写操作,输出锁存器的内容从引脚输出。

一旦数据写入输出锁存器,它将一直保存到新数据被写入。

当复位信号产生时输出锁存器的内容被清零。

## (2) 输入模式

使用传送指令对输出锁存器进行写操作,因为输出缓冲器处于关闭状态,所以引脚状态不会改变。

一旦数据写入输出锁存器,它将一直保存到新数据被写入。

当复位信号产生时输出锁存器的内容被清零。

#### 5.4.2 从 I/O 端口读取

### (1) 输出模式

使用传送指令读取的是输出锁存器的内容。输出锁存器的内容不会改变。

#### (2) 输入模式

使用传送指令读取的是引脚状态。输出锁存器的内容不会改变。

## 5.4.3 I/O 端口的操作

## (1) 输出模式

对输出锁存器执行一个操作时,操作结果写入输出锁存器。而输出锁存器的内容则从引脚输出。

一旦数据写入输出锁存器,它将一直保存到新数据被写入。

当复位信号的产生时输出锁存器的内容被清零。

# (2) 输入模式

读取引脚电平,对它的内容执行操作,操作的结果写入输出锁存器,因为输出缓冲器处于关闭状态,所以引脚状态不会改变。

当复位信号的产生时输出锁存器的内容被清零。

# 5.5 使用复用功能时端口模式寄存器和输出锁存器的设置

为使用端口引脚的复用功能,应按表 5-5 所示对端口模式寄存器和输出锁存器进行设置。

表 5-5 使用复用功能时,端口模式寄存器和输出锁存器的设置(1/2)

| 引脚名称 | 复用功能  |     | PM×× | P×× |
|------|-------|-----|------|-----|
|      | 功能名称  | I/O |      |     |
| P00  | TI000 | 输入  | 1    | ×   |
| P01  | TI010 | 输入  | 1    | ×   |
|      | TO00  | 输出  | 0    | 0   |
| P02  | SO11  | 输出  | 0    | 0   |
| P03  | SI11  | 输入  | 1    | ×   |
| P04  | SCK11 | 输入  | 1    | ×   |
|      |       | 输出  | 0    | 1   |
| P05  | SSI11 | 输入  | 1    | ×   |
|      | TI001 | 输入  | 1    | ×   |
| P06  | TI011 | 输入  | 1    | ×   |
|      | TO01  | 输出  | 0    | 0   |
| P10  | SCK10 | 输入  | 1    | ×   |
|      |       | 输出  | 0    | 1   |
|      | TxD0  | 输出  | 0    | 1   |
| P11  | SI10  | 输入  | 1    | ×   |
|      | RxD0  | 输入  | 1    | ×   |
| P12  | SO10  | 输出  | 0    | 0   |
| P13  | TxD6  | 输出  | 0    | 1   |
| P14  | RxD6  | 输入  | 1    | ×   |
| P15  | ТОН0  | 输出  | 0    | 0   |
| P16  | TOH1  | 输出  | 0    | 0   |
|      | INTP5 | 输入  | 1    | ×   |
| P17  | TI50  | 输入  | 1    | ×   |
|      | TO50  | 输出  | 0    | 0   |

**备注:** ×: 不必考虑

PM××: 端口模式寄存器 P××: 端口输出锁存器

表 5-5 使用复用功能时,端口模式寄存器和输出锁存器的设置(2/2)

| 引脚名称                                                     | 复用功能                           |     | PM×× | Pxx |
|----------------------------------------------------------|--------------------------------|-----|------|-----|
|                                                          | 功能名称                           | I/O |      |     |
| $\mathrm{P20} \sim \mathrm{P27}^{ \text{\tiny $\pm 1$}}$ | ANIO ~ ANI7 **1                | 输入  | 1    | ×   |
| P30 ~ P32                                                | INTP1 ∼ INTP3                  | 输入  | 1    | ×   |
| P33                                                      | INTP4                          | 输入  | 1    | ×   |
|                                                          | TI51                           | 输入  | 1    | ×   |
|                                                          | TO51                           | 输出  | 0    | 0   |
| P60                                                      | SCL0                           | I/O | 0    | 0   |
| P61                                                      | SDA0                           | I/O | 0    | 0   |
| P62                                                      | EXSCL0                         | 输入  | 1    | ×   |
| P70 ∼ P77                                                | $	extsf{KR0} \sim 	extsf{KR7}$ | 输入  | 1    | ×   |
| P120                                                     | INTP0                          | 输入  | 1    | ×   |
|                                                          | EXLVI                          | 输入  | 1    | ×   |
| P121                                                     | X1 <sup>±2</sup>               | _   | ×    | ×   |
| P122                                                     | X2 <sup>±2</sup>               | -   | ×    | ×   |
|                                                          | EXCLK #2                       | 输入  | ×    | ×   |
| P123                                                     | XT1 <sup>±2</sup>              | _   | ×    | ×   |
| P124                                                     | XT2 <sup>±2</sup>              | -   | ×    | ×   |
|                                                          | EXCLKS **2                     | 输入  | ×    | ×   |
| P140                                                     | PCL                            | 输出  | 0    | 0   |
|                                                          | INTP6                          | 输入  | 1    | ×   |
| P141                                                     | BUZ                            | 输出  | 0    | 0   |
|                                                          | INTP7                          | 输入  | 1    | ×   |
|                                                          | BUSY0                          | 输入  | 1    | ×   |
| P142                                                     | SCKA0                          | 输入  | 1    | ×   |
|                                                          |                                | 输出  | 0    | 1   |
| P143                                                     | SIA0                           | 输入  | 1    | ×   |
| P144                                                     | SOA0                           | 输出  | 0    | 0   |
| P145                                                     | STB0                           | 输出  | 0    | 0   |

**备注:** 1. ×: 不必考虑

PM××: 端口模式寄存器 P××: 端口输出锁存器

**2.** 若要使用片上调试功能,可以通过*μ*PD78F0547D 的 X1、X2、P31 和 P32 引脚进行设置(OCD0A, OCD0B, OCD1A, OCD1B)。详细信息可参见**第二十八章 片上调试功能(仅用于***μ***PD78F0547D)**。

(注1和注2在下一页列出。)

★ **注:** 1. ANIO/P20~ ANI7/P27 引脚的功能可以通过使用 A/D 端口配置寄存器(ADPC)、模拟输入通道选择寄存器 (ADS)和 PM2 来选择。

表 5-6 ANIO/P20~ ANI7/P27 引脚的功能设置

| ADPC      | PM2  | ADS      | ANI0/P20~ ANI7/P27 引脚 |
|-----------|------|----------|-----------------------|
| 模拟输入选择    | 输入模式 | 选择 ANI.  | 模拟输入 (被转换)            |
|           |      | 不选择 ANI. | 模拟输入 (不被转换)           |
|           | 输出模式 | 选择 ANI.  | 禁止设置                  |
|           |      | 不选择 ANI. |                       |
| 数字 I/O 选择 | 输入模式 | 选择 ANI.  | 禁止设置                  |
|           |      | 不选择 ANI. | 数字输入                  |
|           | 输出模式 | 选择 ANI.  | 禁止设置                  |
|           |      | 不选择 ANI. | 数字输出                  |

2. 当使用 P121~ P124 引脚连接主系统时钟(X1,X2)或子系统时钟(XT1,XT2)的振荡器,或者输入该主系统时钟的外部时钟(EXCLK)或子系统时钟的外部时钟(EXCLKS)时,必须通过使用时钟操作模式选择寄存器(OSCCTL)对 X1 振荡模式、XT1 振荡模式或者外部时钟输入模式进行设置(如需了解详细信息,可参见 6.3 (1) 时钟操作模式选择寄存器(OSCCTL)和(3)子系统时钟引脚操作模式设置)。OSCCTL 的复位值为 00H(P121~ P124 都用作 I/O 端口引脚)。在这种情况下,不必对PM121~ PM124 和 P121~ P124 引脚进行设置。

124

## 第六章 时钟发生器

### 6.1 时钟发生器的功能

时钟发生器用于产生时钟,并提供给 CPU 和外部硬件设备。可以使用以下三种系统时钟和时钟振荡器。

#### (1) 主系统时钟

#### <1> X1 振荡器

通过连接一个振荡器到 X1 和 X2,该振荡电路产生 fx = 1 到 20MHz 的时钟。通过执行 STOP 指令或设置主 OSC 控制寄存器(MOC),可以停止振荡。

#### <2> 内部高速振荡器

这个振荡电路产生一个 fret = 8 MHz (TYP.)的时钟。复位释放后,CPU 总是使用这个内部高速振荡时钟进行操作。可以通过执行 STOP 指令或者使用内部振荡模式寄存器(RCM)停止其振荡。

外部主系统时钟(fexclx = 1 到 20 MHz)也可以通过 EXCLK/X2/P122 引脚提供。可以通过执行 STOP 指令或者使用 RCM 禁止外部主系统时钟输入。

可以通过使用主时钟模式寄存器(MCM)选择内部高速系统时钟(X1 时钟或者外部主系统时钟)或内部高速振荡时钟,作为主系统时钟。

### (2) 子系统时钟

#### • 子系统时钟振荡器

通过在 XT1 和 XT2 之间连接一个 32.768kHz 的振荡器,该电路以 fxr = 32.768 kHz 的频率进行振荡。通过使用处理器时钟控制寄存器(PCC)和时钟操作模式选择寄存器(OSCCTL),可以停止振荡。

还可以通过 EXCLKS/XT2/P124 引脚提供一个外部子系统时钟 (fexclks = 32.768 kHz)。可以通过设置 PCC 和 OSCCTL 禁止外部子系统时钟输入。

**备注:** 1. fx: X1 时钟振荡频率

2. fr.H: 内部高速振荡时钟频率

**3.** fexclk: 外部主系统时钟频率

**4.** fxT: XT1 时钟振荡频率

5. fexclks: 外部子系统时钟频率

# (3) 内部低速振荡时钟(看门狗定时器时钟)

## • 内部低速振荡器

该电路以 frL = 240 kHz (TYP.)的时钟振荡。复位释放后,内部低速振荡时钟总是启动操作。

★ 当通过选项字节设置"内部低速振荡器可由软件停止"时,可以通过使用内部振荡模式寄存器(RCM)停止其振荡。

内部低速振荡时钟不能作为 CPU 时钟。如下硬件使用内部低速振荡时钟。

- 看门狗定时器
- TMH1 (选择 fRL,fRL/2<sup>7</sup>或 fRL/2<sup>9</sup>时)

**备注:** fRL: 内部低速振荡时钟频率

# 6.2 时钟发生器的构成

时钟发生器包括以下硬件。

表 6-1 时钟发生器的构成

| 项目    | 构成                                                                                                                                              |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 控制寄存器 | 时钟操作模式选择寄存器(OSCCTL)<br>处理器时钟控制寄存器 (PCC)<br>内部振荡模式寄存器 (RCM)<br>主 OSC 控制寄存器 (MOC)<br>主时钟模式寄存器 (MCM)<br>振荡稳定时间计数器的状态寄存器(OSTC)<br>振荡稳定时间选择寄存器(OSTS) |  |
| 振荡器   | X1 振荡器<br>XT1 振荡器<br>内部高速振荡器                                                                                                                    |  |



127

**备注:** 1. fx: X1 时钟振荡频率

**2.** frh: 内部高速振荡时钟频率 3. fexclk: 外部主系统时钟频率 **4.** fxH: 高速系统时钟振荡频率 **5.** fxp: 主系统时钟振荡频率 **6.** fprs: 外部硬件时钟振荡频率 **7.** fcpu: CPU 时钟振荡频率 **8.** fxT: XT1 时钟振荡频率 9. fexclks: 外部子系统时钟频率 **10.** fsua: 子系统时钟振荡频率

内部低速振荡时钟频率

### 6.3 控制时钟发生器的寄存器

**11.** frL:

以下七种寄存器用于控制时钟发生器。

- 时钟操作模式选择寄存器 (OSCCTL)
- 处理器时钟控制寄存器 (PCC)
- 内部振荡模式寄存器 (RCM)
- 主 OSC 控制寄存器(MOC)
- 主时钟模式寄存器 (MCM)
- 振荡稳定时间计数器的状态寄存器 (OSTC)
- 振荡稳定时间选择寄存器 (OSTS)

## (1) 时钟操作模式选择寄存器 (OSCCTL)

该寄存器用于选择高速系统和子系统时钟的操作模式,以及内置振荡器的获取方式。可由一个 1 位或 8 位存储器操作指令设置 OSCCTL。 复位信号的产生可将这个寄存器设置为 00H。

## 图 6-2 时钟操作模式选择寄存器的格式 (OSCCTL)

地址: FF9FH 复位后: 00H R/W

符号 <7> <6> <5> <4> 3 2 <0> EXCLKS \*\* OSCSELS \*\* OSCCTL **EXCLK** OSCSEL 0 0 0 AMPH

| EXCLK | OSCSEL | 高速系统时钟引脚操作模<br>式 | P121/X1 引脚 | P122/X2/EXCLK 引脚 |
|-------|--------|------------------|------------|------------------|
| 0     | 0      | I/O 端口模式         | I/O 端口     |                  |
| 0     | 1      | X1 振荡模式          | 晶体/陶瓷振荡器连接 |                  |
| 1     | 0      | I/O 端口模式         | I/O 端口     |                  |
| 1     | 1      | 外部时钟输入模式         | I/O 端口     | 外部时钟输入           |

| AMPH | 操作频率控制                |
|------|-----------------------|
| 0    | 1 MHz ≤ fxH ≤ 10 MHz  |
| 1    | 10 MHz < fxн ≤ 20 MHz |

注: EXCLKS 和 OSCSELS 与 XTSTART(处理器时钟控制寄存器 (PCC)的第 6 位)结合使用。 参见 (3) 子系统时钟引脚操作模式的设置。

注意事项: 1. 如果高速系统时钟振荡频率超过 10MHz,则必须将 AMPH 设置为 1。

- 2. 复位释放后外部功能设置之前应设置 AMPH。复位释放后 AMPH 的值只能被修改一次。在 AMPH 被设置为 1 后,CPU 时钟供应将停止 5 μs (MIN.)。
- 3. 当内部高速振荡时钟或者外部主系统时钟作为 CPU 时钟使用且 AMPH=1 时,执行 STOP 指令,则在 STOP 模式释放后,CPU 时钟会停止 5 μs (MIN.)。如果 X1 时钟用作 CPU 时钟,振荡稳定时间从 STOP 模式释放后开始计算。
- 4. 若要修改 EXCLK 和 OSCSEL, 必须确保主 OSC 控制寄存器(MOC)的第7位(MSTOP) =1(X1 振荡器停止或禁止使用来自 EXCLK 引脚的外部时钟)。

**备注:** fxH: 高速系统时钟振荡频率

## (2) 处理器时钟控制寄存器(PCC)

PCC 用于选择 CPU 时钟、分频比和子系统时钟的操作模式。由 1 位或 8 位存储器操作指令设置 PCC。 复位信号的产生可将 PCC 设置为 01H。

### 图 6-3 处理器时钟控制寄存器(PCC)的格式

地址: FFFBH 复位后: 01H R/W<sup>±1</sup>

| 符号  | 7 | 6                      | <5> | <4> | 3 | 2    | 1    | 0    |
|-----|---|------------------------|-----|-----|---|------|------|------|
| PCC | 0 | XTSTART <sup>2</sup> 2 | CLS | CSS | 0 | PCC2 | PCC1 | PCC0 |

| CLS | CPU 时钟状态 |
|-----|----------|
| 0   | 主系统时钟    |
| 1   | 子系统时钟    |

| CSS | PCC2 | PCC1 | PCC0 | CPU 时钟 (fcpu) 选择   |  |
|-----|------|------|------|--------------------|--|
| 0   | 0    | 0    | 0    | fxp                |  |
|     | 0    | 0    | 1    | fxp/2 (默认)         |  |
|     | 0    | 1    | 0    | fxp/2 <sup>2</sup> |  |
|     | 0    | 1    | 1    | fxp/2 <sup>3</sup> |  |
|     | 1    | 0    | 0    | fxp/2 <sup>4</sup> |  |
| 1   | 0    | 0    | 0    | fsua/2             |  |
|     | 0    | 0    | 1    |                    |  |
|     | 0    | 1    | 0    |                    |  |
|     | 0    | 1    | 1    |                    |  |
|     | 1    | 0    | 0    |                    |  |
|     | 其他   | 情况   | •    | 禁止设置               |  |

## 注: 1. 第5位只读。

2. XTSTART 与 EXCLKS 和 OSCSELS (时钟操作模式选择寄存器(OSCCTL)的第 5 位和第 4 位)结合使用。参见 (3) 子系统时钟引脚操作模式的设置。

# 注意事项: 必须将第3位和第7位清零。

**备注:** 1. fxp: 主系统时钟振荡频率

2. fsua: 子系统时钟振荡频率

在 78K0/KF2+中执行速度最快的指令执行时间在 2 个 CPU 时钟以内。CPU 时钟(fcpu)与指令最短执行时间的关系 如表 6-2 所示。

表 6-2 CPU 时钟与指令最短执行时间的关系

| CPU 时钟(fCPU)       | 指令最短执行时间: 2/fcpu |                        |                       |                  |  |  |  |
|--------------------|------------------|------------------------|-----------------------|------------------|--|--|--|
|                    |                  | 主系                     | 统时钟                   | 子系统时钟            |  |  |  |
|                    | 高速系              | 统时钟 <sup>推</sup>       | 内部高速振荡时钟 <sup>推</sup> |                  |  |  |  |
|                    | 操作频率:<br>10 MHz  | 操作频率:<br>20 <b>MHz</b> | 操作频率: 8 MHz (TYP.)    | 操作频率: 32.768 kHz |  |  |  |
| fxp                | 0.2 μs           | 0.1 <i>μ</i> s         | 0.25 μs (TYP.)        | -                |  |  |  |
| fxp/2              | 0.4 μs           | 0.2 μs                 | 0.5 μs (TYP.)         | -                |  |  |  |
| fxp/2 <sup>2</sup> | 0.8 <i>μ</i> s   | 0.4 <i>μ</i> s         | 1.0 μs (TYP.)         | -                |  |  |  |
| fxp/2 <sup>3</sup> | 1.6 <i>μ</i> s   | 0.8 μs                 | 2.0 μs (TYP.)         | -                |  |  |  |
| fxp/2 <sup>4</sup> | 3.2 μs           | 1.6 <i>μ</i> s         | 4.0 μs (TYP.)         | -                |  |  |  |
| fsuB/2             |                  | _                      | -                     | 122.1 μs         |  |  |  |

注: 主时钟模式寄存器(MCM)用于设置提供给 CPU 的主系统时钟(高速系统时钟/内部高速振荡时钟) (参见图 6-6)。

## ★ (3) 子系统时钟引脚操作模式的设置

使用处理器时钟控制寄存器(PCC)的第 6 位(XTSTART)和时钟操作模式选择寄存器(OSCCTL)的第 5 位与第 4 位 (EXCLKS, OSCSELS)共同设置子系统时钟引脚操作模式。

表 6-3 子系统时钟引脚操作模式的设置

| PCC     | OSCCTL |         | 子系统时钟引脚操作模式 | P123/XT1 引脚 | P124/XT2/EXCLKS 引 |  |
|---------|--------|---------|-------------|-------------|-------------------|--|
| 第6位     | 第5位    | 第4位     |             | 脚           |                   |  |
| XTSTART | EXCLKS | OSCSELS |             |             |                   |  |
| 0       | 0      | 0       | I/O 端口模式    | I/O 端口      |                   |  |
| 0       | 0      | 1       | XT1 振荡模式    | 晶体振荡器连接     |                   |  |
| 0       | 1      | 0       | I/O 端口模式    | I/O 端口      |                   |  |
| 0       | 1      | 1       | 外部时钟输入模式    | I/O 端口      | 外部时钟输入            |  |
| 1       | ×      | ×       | XT1 振荡模式    | 晶体振荡器连接     |                   |  |

注意事项: 改变 XTSTART、EXCLKS 和 OSCSELS 的当前值时,应确保处理器时钟控制寄存器(PCC)的第 5 位 (CLS) =0(CPU 使用主系统时钟)。

**备注:** ×: 不必考虑

## (4) 内部振荡模式寄存器 (RCM)

内部振荡模式寄存器用于设置内部振荡器操作模式。由 1 位或 8 位存储器操作指令设置 RCM。 复位信号的产生可将该寄存器设置为 80H <sup>± 1</sup>。

#### 图 6-4 内部振荡模式寄存器(RCM)的格式

地址: FFA0H 复位后: 80H<sup>±1</sup> R/W<sup>±2</sup>

| 符号  | <7>  | 6 | 5 | 4 | 3 | 2 | <1>     | <0>   |
|-----|------|---|---|---|---|---|---------|-------|
| RCM | RSTS | 0 | 0 | 0 | 0 | 0 | LSRSTOP | RSTOP |

| RSTS | 内部高速振荡器状态     |
|------|---------------|
| 0    | 等待内部高速振荡器精确稳定 |
| 1    | 内部高速振荡器的稳定操作  |

| LSRSTOP | 内部低速振荡器振荡/停止 |
|---------|--------------|
| 0       | 内部低速振荡器振荡    |
| 1       | 内部低速振荡器停止    |

| RSTOP | 内部高速振荡器振荡/停止 |
|-------|--------------|
| 0     | 内部高速振荡器振荡    |
| 1     | 内部高速振荡器停止    |

注: 1. 复位释放后寄存器的值立即变为 00H, 但在内部高速振荡器稳定后又自动变为 80H。

2. 第7位为只读。

注意事项: 当设置 RSTOP =1 时,必须确保 CPU 使用的不是内部高速振荡时钟。特别地,在下列任一条件下,可以设置 RSTOP =1。

- 当 MCS = 1 (当 CPU 使用高速系统时钟时)
- 当 CLS = 1 (当 CPU 使用子系统时钟时)

此外,在将 RSTOP 设置为 1 之前应停止正在使用内部高速振荡时钟操作的外部硬件。

## (5) 主 OSC 控制寄存器 (MOC)

MOC 用于选择高速系统时钟的操作模式。

当 CPU 不使用高速系统时钟时,该寄存器用于停止 X1 振荡器或禁止 EXCLK 引脚的外部时钟输入。

可以用 1 位或 8 位存储器操作指令设置 MOC。

复位信号的产生可将该寄存器设置为 80H。

# 图 6-5 主 OSC 控制寄存器 (MOC)的格式

地址: FFA2H 复位后: 80H R/W

| 符号  | <7>   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|-------|---|---|---|---|---|---|---|
| MOC | MSTOP | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| MSTOP | 高速系统时钟操作控制 |                      |  |  |  |  |  |
|-------|------------|----------------------|--|--|--|--|--|
|       | X1 振荡模式    | 外部时钟输入模式             |  |  |  |  |  |
| 0     | X1 振荡器操作   | 允许使用来自 EXCLK 引脚的外部时钟 |  |  |  |  |  |
| 1     | X1 振荡器停止   | 禁止使用来自 EXCLK 引脚的外部时钟 |  |  |  |  |  |

- 注意事项: 1. 设置 MSTOP = 1 时,必须确保 CPU 使用的不是高速系统时钟。特别地,在下列任一条件下,可以设置 MSTOP = 1。
  - 当 MCS = 0 (当 CPU 使用内部高速振荡时钟时)
  - 当 CLS = 1 (当 CPU 使用子系统时钟时)

此外,在设置 MSTOP 为 1 之前应停止正在使用高速系统时钟操作的外部硬件。

- 2. 当时钟操作模式选择寄存器(OSCCTL)的第 6 位(OSCSEL)= 0(I/O 端口模式)时,不要将 MSTOP 清零。
- 3. 外部硬件时钟停止时外部硬件不能操作。外部硬件时钟停止后,若要恢复外部硬件的操作,则必须初始化外部硬件。

## (6) 主时钟模式寄存器 (MCM)

MCM 用于选择提供给 CPU 的主系统时钟和外部硬件时钟。由 1 位或 8 位存储器操作指令设置 MCM。 复位信号的产生可对寄存器清零(00H)。

#### 图 6-6 主时钟模式寄存器 (MCM)的格式

地址: FFA1H 复位后: 00H R/W \*\*

| 符号  | 7 | 6 | 5 | 4 | 3 | <2>  | <1> | <0>  |
|-----|---|---|---|---|---|------|-----|------|
| MCM | 0 | 0 | 0 | 0 | 0 | XSEL | MCS | мсмо |

| XSEL | MCM0 | 主系统和外部硬件的时钟选择 |                |  |
|------|------|---------------|----------------|--|
|      |      | 主系统时钟 (fxP)   | 外部硬件时钟 (fprs)  |  |
| 0    | 0    | 内部高速振荡时钟(frH) | 内部高速振荡时钟 (fRH) |  |
| 0    | 1    |               |                |  |
| 1    | 0    |               | 高速系统时钟 (fxн)   |  |
| 1    | 1    | 高速系统时钟 (fxH)  |                |  |

| MCS | 主系统时钟状态    |  |  |  |  |
|-----|------------|--|--|--|--|
| 0   | 使用内部高速振荡时钟 |  |  |  |  |
| 1   | 使用高速系统时钟   |  |  |  |  |

注:第1位只读。

注意事项: 1. XSEL 在复位释放后只能被修改一次。

- 2. 无论 XSEL 和 MCM0 如何设置,除了 fPRS 以外的一个时钟将被提供给如下外围硬件功能
  - 看门狗定时器(使用内部低速振荡时钟)
  - 选择"fRL", "fRL/2<sup>7</sup>", 或者 "fRL/2<sup>9</sup>"作为 8 位定时器 H1 的计数时钟(使用内部低速振荡时钟)
  - 选择外部时钟作为外部硬件的时钟源 (以下情况除外: 选择 TM0n (n = 0, 1)的外部计数时钟(Tl00n 有效沿)时)

## (7) 振荡稳定时间计数器的状态寄存器 (OSTC)

该寄存器用于指示 X1 时钟振荡稳定时间计数器的计数状态。当 X1 时钟振荡启动时,使用内部高速振荡时钟或子系统时钟作为 CPU 时钟,X1 时钟振荡稳定时间可以被检测。

可以由 1 位或 8 位存储器操作指令读取 OSTC 的内容。

复位释放后(由 RESET 输入、POC、LVI、和 WDT 进行复位),通过 STOP 指令,以及设置 MSTOP(MOC 寄存器的第7位) = 1,可以对 OSTC 清零(00H)。

图 6-7 振荡稳定时间计数器的状态寄存器(OSTC)的格式

 地址: FFA3H
 复位后: 00H
 R

 符号
 7
 6
 5
 4
 3
 2
 1
 0

 OSTC
 0
 0
 MOST11
 MOST13
 MOST14
 MOST15
 MOST16

| MOST11 | MOST13 | MOST14 | MOST15 | MOST16 | 振荡稳定时间的状态                |               |               |
|--------|--------|--------|--------|--------|--------------------------|---------------|---------------|
|        |        |        |        |        |                          | fx = 10  MHz  | fx = 20 MHz   |
| 1      | 0      | 0      | 0      | 0      | 2 <sup>11</sup> /fx min. | 204.8 μs min. | 102.4 μs min. |
| 1      | 1      | 0      | 0      | 0      | 2 <sup>13</sup> /fx min. | 819.2 μs min. | 409.6 μs min. |
| 1      | 1      | 1      | 0      | 0      | 2 <sup>14</sup> /fx min. | 1.64 ms min.  | 819.2 µs min. |
| 1      | 1      | 1      | 1      | 0      | 2 <sup>15</sup> /fx min. | 3.27 ms min.  | 1.64 ms min.  |
| 1      | 1      | 1      | 1      | 1      | 2 <sup>16</sup> /fx min. | 6.55 ms min.  | 3.27 ms min.  |

注意事项: 1.在经过上述稳定时间后,从 MOST11 开始的位依次被设置为 1,并一直保持。

- 2.振荡稳定时间计数器值增加到由 OSTS 设置的振荡稳定时间。当内部高速振荡时钟作 为 CPU 时钟,如果已进入 STOP 模式,在释放该模式时,按如下方式设置振荡稳定时 间。
  - 预期的 OSTC 振荡稳定时间 ≤ 由 OSTS 设置的振荡稳定时间。

注意,在 STOP 模式释放后,仅将达到振荡稳定时间(由 OSTS 设置)的状态赋给 OSTC。

3.X1 时钟振荡稳定等待时间不包括时钟振荡开始之前的时间(下图 "a"表示的部分)。



**备注:** fx: X1 时钟振荡频率

## (8) 振荡稳定时间选择寄存器 (OSTS)

OSTS 用于选择 X1 时钟振荡稳定等待时间(当 STOP 模式释放时)。

当 CPU 使用 X1 时钟且 STOP 模式释放后,等待由 OSTS 设置的时间。

★ 当 CPU 使用内部高速振荡时钟时,应使用 OSTC 确认 STOP 模式释放后已经经历了所要求的振荡稳定时间。可以 使用 OSTC 检测振荡稳定时间。

可以由8位存储器操作指令设置OSTS。

复位信号的产生将 OSTS 内容设置为 05H。

图 6-8 振荡稳定时间选择寄存器(OSTS)的格式

地址: FFA4H 复位后: 05H R/W

| 符号   | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     |
|------|---|---|---|---|---|-------|-------|-------|
| OSTS | 0 | 0 | 0 | 0 | 0 | OSTS2 | OSTS1 | OSTS0 |

| OSTS2 | OSTS1 | OSTS0 | 振荡稳定时间的选择           |                  |                  |
|-------|-------|-------|---------------------|------------------|------------------|
|       |       |       |                     | fx = 10 MHz      | fx = 20 MHz      |
| 0     | 0     | 1     | 2 <sup>11</sup> /fx | 204.8 μs         | 102.4 <i>μ</i> s |
| 0     | 1     | 0     | 2 <sup>13</sup> /fx | 819.2 <i>μ</i> s | 409.6 μs         |
| 0     | 1     | 1     | 2 <sup>14</sup> /fx | 1.64 ms          | 819.2 μs         |
| 1     | 0     | 0     | 2 <sup>15</sup> /fx | 3.27 ms          | 1.64 ms          |
| 1     | 0     | 1     | 2 <sup>16</sup> /fx | 6.55 ms          | 3.27 ms          |
|       | 其他情况  |       | 禁止设置                |                  |                  |

- 注意事项: 1. 当 CPU 使用 X1 时钟时,若要设置 STOP 模式,则必须在执行 STOP 指令之前设置 OSTS。
  - 2. 在 X1 时钟振荡稳定时间内不要改变 OSTS 的值。
  - 3. 振荡稳定时间计数器值增加到由 OSTS 设置的振荡稳定时间。CPU 使用内部高速振荡时钟时,如果已进入 STOP 模式,在释放该模式时,按如下方式设置振荡稳定时间。
    - 预期的 OSTC 振荡稳定时间 ≤ 由 OSTS 设置的振荡稳定时间。

注意,在 STOP 模式释放后,仅将达到振荡稳定时间的状态(由 OSTS 设置)赋给 OSTC。

4. X1 时钟振荡稳定等待时间不包括时钟振荡开始之前的时间(下图 "a"表示的部分)。



**备注:** fx: X1 时钟振荡频率

# 6.4 系统时钟振荡器

#### 6.4.1 X1 振荡器

X1 振荡器采用晶体振荡器或陶瓷振荡器(1 到 20MHz,连接到 X1 和 X2 引脚)进行操作。图 6-9 为 X1 振荡器的外部电路示例。

图 6-9 X1 振荡器的外部电路示例(晶体或陶瓷振荡)



使用时的注意事项在下页列出。

#### 6.4.2 XT1 振荡器

XT1 振荡器采用晶体振荡器(连接到 XT1 和 XT2 引脚,标准值为: 32.768 kHz)进行操作。图 6-10 为 XT1 振荡器的外部电路示例。

图 6-10 XT1 振荡器的外部电路示例(晶体振荡)



使用时的注意事项在下页列出。

注意事项: 1. 在使用 X1 振荡器和 XT1 振荡器时,图 6-9 和图 6-10 中被虚线包围的部分的配线应按照如下配线方法 配线,以防止连接线电容产生不利影响。

- 连接线越短越好。
- 连接线不应与其他信号线交叉。流经的电流变化较大的信号线不要在振荡器周围布线。
- 要保持振荡器电容器的接地点电压与 Vss 相同。不要将电容的地信号接入大电流地。
- 不要从振荡器获取信号。

注意,XT1 振荡器被设计成低振幅电路,以降低功耗。

图 6-11 为不正确的振荡器连接示例。

图 6-11. 不正确的振荡器连接示例 (1/2)



备注: 在使用子系统时钟时,分别用 XT1 和 XT2 代替 X1 和 X2。串联电阻也插在 XT2 这边。

图 6-11. 不正确的振荡器连接示例 (2/2)

# (c) 连接线周围有高变化电流







# (e) 获取信号



备注: 在使用子系统时钟时,分别用 XT1 和 XT2 代替 X1 和 X2。串联电阻也插在 XT2 这边。

注意事项: 2. 当 X2 和 XT1 并行连接时, X2 的串扰噪音会叠加到 XT1, 从而产生错误。

#### 6.4.3 不使用子系统时钟

为了降低功耗,如果无需使用子系统时钟,或者不使用子系统时钟作为 I/O 端口,则可以设置 XT1 和 XT2 引脚为★ I/O 模式(OSCSELS = 0),并按下列方式进行连接。

★ 输入 (PM123/PM124 = 1): 通过一个电阻独立连接到 VDD 或 Vss。

输出 (PM123/PM124 = 0): 保持开路。

备注: OSCSELS: 时钟操作模式选择寄存器的第 4 位 (OSCCTL)

PM123, PM124: 端口模式寄存器 12 的第 3 位和第 4 位 4 (PM12)

#### 6.4.4 内部高速振荡器

78K0/KF2 产品中包含内部高速振荡器。可以通过内部振荡模式寄存器(RCM)控制振荡。

复位释放后,内部高速振荡器自动开始振荡(8MHz (TYP.))。

#### 6.4.5 内部低速振荡器

78K0/KF2产品中包含内部低速振荡器。

内部低速振荡时钟只作为看门狗定时器和8位定时器 H1 的时钟使用。内部低速振荡时钟不能用作 CPU 时钟。

可以通过选项字节选择内部低速振荡器"可由软件停止"或"不能停止"。如果设置"可由软件停止",则可由内部振荡模式寄存器(RCM)控制振荡。

复位释放后,内部低速振荡器自动产生振荡,同时如果使用选项字节允许看门狗定时器操作,则可以驱动看门狗定时器 (240 kHz (TYP.))。

# 6.4.6 预分频器

当 CPU 使用主系统时钟时,通过分频主系统时钟,预分频器可以产生多种时钟。

## 6.5 时钟发生器的操作

时钟发生器用于产生以下几种时钟,并控制 CPU 的操作模式,如待机模式。(见图 6-1).

- 主系统时钟 fxp
  - 高速系统时钟 fxH

X1 时钟 fx

外部主系统时钟 fexclk

- 内部高速振荡时钟 fRH
- 子系统时钟 fsua
  - XT1 时钟 fxT
  - 外部子系统时钟 fexclks
- 内部低速振荡时钟 fRL
- CPU 时钟 fcpu
- 外部硬件时钟 fprs

在 78K0/KF2 中, 当复位释放后内部高速振荡器输出时, CPU 开始操作, 因此具有以下特点。

#### (1) 增强安全功能

如果 X1 时钟被默认设置为 CPU 时钟,在 X1 时钟遭到损坏或未连接时设备不能操作,因此复位释放后也不能操作。但是,如果 CPU 的初始时钟是内部高速振荡时钟,则在复位释放后,由内部高速振荡时钟启动设备。这样,系统只需执行最少操作(如由软件确认复位源或在出现故障时执行安全处理),便可以安全关闭。

#### (2) 改善性能

由于 CPU 可以在不必等待 X1 时钟振荡稳定时间情况下就启动,所以总的性能得到了改善。图 6-12 为上电时,时钟发生器的操作图。

# 图 6-12 上电时的时钟发生器操作 (设置 1.59 V POC 模式 (选项字节: POCMODE = 0))



- <1> 当电源开启时,通过上电清零 (POC) 电路产生一个内部复位信号。
- <2> 当供电电压超过 1.59 V (TYP.),复位释放并且内部高速振荡器自动开始振荡。
- <3> 当供电电压上升斜率为 0.5 V/ms (MAX.)时,复位释放并且在经历了供电电压和稳压器的稳定时间后,CPU 开始使用内部高速振荡时钟,然后进行复位处理。
- <4> 通过软件设置 X1 或 XT1 时钟的振荡开始(参见 6.6.1 高速系统时钟控制示例中的(1)和 6.6.3 子系统时钟控制示例中的(1))。
- <5> 当 CPU 时钟切换到 X1 或 XT1 时钟时,等待时钟振荡稳定,然后通过软件设置切换(参见 6.6.1 高速系统时钟控制示例中的(3)和 6.6.3 子系统时钟控制示例中的(3))。
- 注: 释放复位后(如上图所示)或在 CPU 使用内部高速振荡时钟时释放 STOP 模式后,使用振荡稳定时间计数器的 状态寄存器(OSTC)来确认 X1 时钟的振荡稳定时间。如果 CPU 使用高速系统时钟(X1 振荡),则可使用振荡稳定时间选择寄存器(OSTS)设置释放 STOP 模式时的振荡稳定时间。
- 注意事项: 1. 在供电电压达到 1.8V 之前,如果电压上升斜率小于 0.5 V/ms (MAX.),则输入一个低电平到电源的 RESET 引脚直至电压达到 1.8V,或者通过使用选项字节(POCMODE = 1)设置 2.7 V/1.59 V POC 模式(见图 6-13)。通过这种方式,CPU 的操作时序与 <2> 及由 RESET 引脚释放复位后的时序相同,如图 6-12 所示。
  - 2. 当使用 EXCLK 和 EXCLKS 引脚的外部时钟输入时,不需要等待振荡稳定时间。

**备注:** 当微控制器正在操作时,不作为 CPU 时钟使用的时钟可以通过软件设置来停止。内部高速振荡时钟和高速系统时钟可以通过执行 STOP 指令来停止(参见 **6.6.1** 高速系统时钟控制示例中的**(4)**和 **6.6.3** 子系统时钟控制示例中的**(4)**0。





- <1> 当电源开启时,通过上电清零 (POC) 电路产生一个内部复位信号。
- <2> 当供电电压超过 2.7 V (TYP.),复位释放并且内部高速振荡器自动开始振荡。
- <3> 复位释放并进行了复位处理后, CPU 开始使用内部高速振荡时钟操作。
- <4> 通过软件设置 X1 或 XT1 时钟的振荡开始(参见 6.6.1 高速系统时钟控制示例中的(1)和 6.6.3 子系统时钟控制示例中的(1))。
- <5> 当 CPU 时钟切换到 X1 或 XT1 时钟时,等待时钟振荡稳定,然后通过软件设置切换(参见 6.6.1 高速系统时钟 控制示例中的(3)和 6.6.3 子系统时钟控制示例中的(3))。
- 注: 释放复位后(如上图所示)或在 CPU 使用内部高速振荡时钟时释放 STOP 模式后,使用振荡稳定时间计数器的 状态寄存器(OSTC)来确认 X1 时钟的振荡稳定时间。如果 CPU 使用高速系统时钟(X1 振荡),则可使用振荡稳定时间选择寄存器(OSTS)设置释放 STOP 模式时的振荡稳定时间。

注意事项: 当使用 EXCLK 和 EXCLKS 引脚的外部时钟输入时,不需要等待振荡稳定时间。

**备注:** 当微控制器正在操作时,不作为 CPU 时钟使用的时钟可以通过软件设置来停止。内部高速振荡时钟和高速系统时钟可以通过执行 STOP 指令来停止(参见 **6.6.1 高速系统时钟控制示例**中的**(4)**和 **6.6.3 子系统时钟控制示例**中的**(4)**)。

#### 6.6 时钟控制

#### ★ 6.6.1 高速系统时钟控制

如下两种高速系统时钟可用。

• X1 时钟: 晶体/陶瓷振荡器连接到 X1 和 X2 引脚。

• 外部主系统时钟: 外部时钟输入到 EXCLK 引脚。

不使用高速系统时钟时, X1/P121 和 X2/EXCLK/P122 引脚可用作 I/O 端口引脚。

注意事项: 复位释放后, X1/P121 和 X2/EXCLK/P122 引脚在 I/O 端口模式下使用。

下面描述的示例是以下情况时的设置过程示例。

- (1) X1 时钟振荡
- (2) 使用外部主系统时钟
- (3) 将高速系统时钟作为 CPU 时钟和外部硬件时钟
- (4) 停止高速系统时钟

### (1) X1 时钟振荡时设置过程示例

<1> 设置频率(OSCCTL 寄存器)

使用 AMPH, 根据使用频率设置内置振荡器。

| AMPH <sup>≇</sup> | 操作频率控制                |
|-------------------|-----------------------|
| 0                 | 1 MHz ≤ fxн ≤ 10 MHz  |
| 1                 | 10 MHz < fxн ≤ 20 MHz |

**注:** 复位释放后设置外部功能前设置 AMPH。复位释放后 AMPH 的值只能被修改一次。当 AMPH=1 时,CPU 时钟停止 5  $\mu$ s (MIN.)。

**备注:** fxH: 高速系统时钟振荡频率

<2> 设置 P121/X1 和 P122/X2/EXCLK 引脚,并选择 X1 时钟或外部时钟(OSCCTL 寄存器), 当 EXCLK 清零且 OSCSEL 置 1 时,从端口模式切换到 X1 振荡模式

| EXCLK | OSCSEL | 高速系统时钟引脚操作模<br>式 | P121/X1 引脚 | P122/X2/EXCLK 引<br>脚 |
|-------|--------|------------------|------------|----------------------|
| 0     | 1      | X1 振荡模式          | 晶体/陶瓷振荡器连接 | ~ .                  |

<3> 控制 X1 时钟振荡 (MOC 寄存器) 若 MSTOP 被清零,则 X1 振荡器开始振荡。

<4> 等待 X1 时钟振荡稳定

检测 OSTC 寄存器并等待所需的时间。

在等待时间内, 其它软件处理过程的执行可以使用内部高速振荡时钟。

注意事项: 1. 在 X1 时钟运行时,不要改变 EXCLK 和 OSCSEL 的值。

2. 当供电电压达到所用时钟的操作电压后,设置 X1 时钟(参见第三十章 电子产品规范(目标))。

# (2) 使用外部主系统时钟时设置过程示例

<1> 设置频率(OSCCTL 寄存器)

使用 AMPH, 设置使用频率。

| Ĭ | AMPH <sup>≇</sup> | 操作频率控制                |
|---|-------------------|-----------------------|
|   | 0                 | 1 MHz ≤ fxн ≤ 10 MHz  |
| I | 1                 | 10 MHz < fxн ≤ 20 MHz |

**注:** 复位释放后设置外部功能前设置 AMPH。复位释放后 AMPH 的值只能被修改一次。当 AMPH=1 时,CPU 时钟停止 5 μs (MIN.)。

**备注:** fxH: 高速系统时钟振荡频率

<2> 设置 P121/X1 和 P122/X2/EXCLK 引脚并选择操作模式(OSCCTL 寄存器)

当 EXCLK 和 OSCSEL 置 1 时,从端口模式切换到外部时钟输入模式。

| EXCLK | OSCSEL | 高速系统时钟引脚操作模<br>式 | P121/X1 引脚 | P122/X2/EXCLK 引<br>脚 |
|-------|--------|------------------|------------|----------------------|
| 1     | 1      | 外部时钟输入模式         | I/O 端口     | 外部时钟输入               |

<3> 控制外部主系统时钟输入(MOC 寄存器) MSTOP 清零时,允许外部主系统时钟输入。

注意事项: 1. 在外部主系统时钟运行时,不要改变 EXCLK 和 OSCSEL 的值。

- 2. 当供电电压达到所用时钟的操作电压后,设置外部主系统时钟(参见第三十章 电子产品规范(目标))。
- (3) 使用高速系统时钟作为 CPU 时钟和外部硬件时钟时设置过程示例
  - <1> 设置高速系统时钟振荡<sup>推</sup>

(参见 6.6.1 (1) X1 时钟振荡时设置过程示例和 (2) 使用外部主系统时钟时设置过程示例。)

注: 当高速系统时钟已经运行时,不需要设置<1>。

# <2> 设置高速系统时钟作为主系统时钟(MCM 寄存器)

XSEL 和 MCMO 置 1 时, 高速系统时钟作为主系统时钟和外部硬件时钟。

| XSEL | мсмо | 主系统时钟和外部     | 邻硬件时钟的选择      |
|------|------|--------------|---------------|
|      |      | 主系统时钟 (fxp)  | 外部硬件时钟 (fprs) |
| 1    | 1    | 高速系统时钟 (fxH) | 高速系统时钟 (fxн)  |

注意事项:如果选择高速系统时钟作为主系统时钟,则只有高速系统时钟可以被设置为外部硬件时钟。

# <3> 设置主系统时钟作为 CPU 时钟并选择分频比(PCC 寄存器)

CSS 清零时,主系统时钟提供给 CPU。若要选择 CPU 时钟分频比,应使用 PCC0、PCC1 和 PCC2。

| CSS | PCC2 | PCC1 | PCC0 | CPU 时钟 (fcpu) 选择   |
|-----|------|------|------|--------------------|
| 0   | 0    | 0    | 0    | fxp                |
|     | 0    | 0    | 1    | fxp/2 (默认)         |
|     | 0    | 1    | 0    | fxp/2 <sup>2</sup> |
|     | 0    | 1    | 1    | fxp/2 <sup>3</sup> |
|     | 1    | 0    | 0    | fxp/2 <sup>4</sup> |
|     | 其他情况 |      |      | 禁止设置               |

### (4) 停止高速系统时钟时设置过程示例

高速系统时钟可以用如下两种方式停止。

- 执行 STOP 指令设置 STOP 模式
- MSTOP 置 1 并停止 X1 振荡(如果使用外部时钟则禁止时钟输入)

# (a) 执行 STOP 指令

<1> 停止外部硬件的设置

停止那些不能在 STOP 模式下使用的外部硬件(需要了解不能在 STOP 模式下使用的外部硬件,可参见第二十二章 待机功能。)

- <2> 释放待机模式后设置 X1 时钟振荡稳定时间
- 当 CPU 使用 X1 时钟时,在 STOP 指令执行前设置 OSTS。
- <3> 执行 STOP 指令

执行 STOP 指令时,系统处于 STOP 模式下并且 X1 振荡停止 (禁止外部时钟输入)。

# (b) 通过将 MSTOP 设置为 1 来停止 X1 振荡(禁止外部时钟输入)

<1> 确认 CPU 时钟状态(PCC 和 MCM 寄存器)

根据 CLS 和 MCS 确认 CPU 没有使用高速系统时钟。

当 CLS = 0 且 MCS = 1 时,CPU 采用高速系统时钟,因此将 CPU 时钟切换为子系统时钟或者内部高速振荡时钟。

| CLS | MCS | CPU 时钟状态 |
|-----|-----|----------|
| 0   | 0   | 内部高速振荡时钟 |
| 0   | 1   | 高速系统时钟   |
| 1   | ×   | 子系统时钟    |

<2> 停止高速系统时钟(MOC 寄存器)

MSTOP 置 1 时,X1 振荡停止(禁止外部时钟输入)。

注意事项: 当 MSTOP= 1 时,必须确认 MCS = 0 或 CLS = 1。此外,必须停止正在使用高速系统时钟的外部硬件。

# ★ 6.6.2 控制内部高速振荡时钟示例

下面描述的示例是以下情况时的设置过程示例。

- (1)内部高速振荡时钟重新开始振荡时
- (2) 使用内部高速振荡时钟作为 CPU 时钟,并且内部高速振荡时钟或高速系统时钟用作外部硬件时钟时
- (3) 停止内部高速振荡时钟时

# (1) 内部高速振荡时钟重新振荡时设置过程示例<sup>±1</sup>

- <1> 内部高速振荡时钟重新振荡的设置(RCM 寄存器) RSTOP 清零时,内部高速振荡时钟开始运行。
- <2> 等待内部高速振荡时钟的振荡精确稳定时间(RCM 寄存器)。
  - 一直到 RSTS = 1 <sup>注 2</sup>.
- 注: 1. 复位释放后,内部高速振荡器自动开始振荡并且内部高速振荡时钟作为 CPU 时钟使用。
  - 2. 如果 CPU 时钟和外部硬件时钟不需要很高的精度,则无需等待时间。

# (2) 使用内部高速振荡时钟作为 CPU 时钟且内部高速振荡时钟或高速系统时钟作为外部硬件时钟时设置过程示例

<1> • 内部高速振荡时钟重新振荡<sup>tt</sup>

(参见 6.6.2 (1) 内部高速振荡时钟重新振荡时设置过程示例)。

• 高速系统时钟振荡<sup>推</sup>

(使用高速系统时钟作为外部硬件时钟时所需的设置。参见 **6.6.1** (1) **X1 时钟振荡时设置过程示例**和(2) 使用外部主系统时钟时设置过程示例。)

注: 当内部高速振荡时钟或高速系统时钟已经运行时,不需要设置<1>。

### <2> 选择主系统时钟和外部硬件时钟(MCM 寄存器)

使用 XSEL 和 MCMO 设置主系统时钟和外部硬件时钟。

| XSEL | МСМ0 | 主系统时钟和外部硬件时钟的选择 |                |  |  |  |
|------|------|-----------------|----------------|--|--|--|
|      |      | 主系统时钟 (fxp)     | 外部硬件时钟 (fprs)  |  |  |  |
| 0    | 0    | 内部高速振荡时钟 (frH)  | 内部高速振荡时钟 (fкн) |  |  |  |
| 0    | 1    |                 |                |  |  |  |
| 1    | 0    |                 | 高速系统时钟(fxH)    |  |  |  |

#### <3> 选择 CPU 时钟分频比(PCC 寄存器)

CSS 清零时,主系统时钟提供给 CPU。若要选择 CPU 时钟分频比,应使用 PCC0、PCC1 和 PCC2。

| CSS | PCC2 | PCC1 | PCC0 | CPU 时钟 (fcpu) 选择                |
|-----|------|------|------|---------------------------------|
| 0   | 0    | 0    | 0    | f <sub>XP</sub>                 |
|     | 0    | 0    | 1    | fxp/2 (默认)                      |
|     | 0    | 1    | 0    | f <sub>xP</sub> /2 <sup>2</sup> |
|     | 0    | 1    | 1    | f <sub>xP</sub> /2 <sup>3</sup> |
|     | 1    | 0    | 0    | f <sub>xP</sub> /2 <sup>4</sup> |
|     | 其他情况 |      |      | 禁止设置                            |

# (3) 停止内部高速振荡时钟时设置过程示例

可以用如下两种方式停止内部高速振荡时钟。

- 执行 STOP 指令设置 STOP 模式
- 将 RSTOP 置 1 且停止内部高速振荡时钟

# (a) 执行 STOP 指令

<1> 设置外部硬件

停止那些不能在 STOP 模式下使用的外部硬件(如需了解不能在 STOP 模式下使用的外部硬件,可参见第二十二章 待机功能)。

<2> 释放待机模式后 X1 时钟振荡稳定时间的设置 CPU 使用 X1 时钟时,在 STOP 指令执行前设置 OSTS。

#### <3> 执行 STOP 指令

执行 STOP 指令时,系统处于 STOP 模式下并且停止内部高速振荡时钟。

### (b) 通过 RSTOP 置 1 停止内部高速振荡时钟

<1> 确认 CPU 时钟状态(PCC 和 MCM 寄存器)

根据 CLS 和 MCS 确认 CPU 没有使用内部高速振荡时钟。

CLS = 0 和 MCS = 0 时,CPU 采用内部高速振荡时钟,因此将 CPU 时钟切换为高速系统时钟或子系统时钟。

| CLS | MCS | CPU 时钟状态 |
|-----|-----|----------|
| 0   | 0   | 内部高速振荡时钟 |
| 0   | 1   | 高速系统时钟   |
| 1   | ×   | 子系统时钟    |

<2> 停止内部高速振荡时钟(RCM 寄存器)

RSTOP 置 1 时,停止内部高速振荡时钟。

注意事项: 当 RSTOP= 1 时,必须确认 MCS = 1 或 CLS = 1。此外,必须停止正在使用内部高速振荡时钟的外部硬件。

### ★ 6.6.3 控制子系统时钟示例

可用如下两种子系统时钟。

• XT1 时钟: 晶体/陶瓷振荡器连接到 XT1 和 XT2 引脚。

• 外部子系统时钟: 外部时钟输入到 EXCLKS 引脚。

不使用子系统时钟时, XT1/P123 和 XT2/EXCLKS/P124 引脚可用作 I/O 端口引脚。

注意事项: 复位释放后 XT1/P123 和 XT2/EXCLKS/P124 引脚在 I/O 端口模式下使用。

下面描述的示例是以下情况时的设置过程示例。

- (1) XT1 时钟振荡
- (2) 使用外部子系统时钟
- (3) 使用子系统时钟作为 CPU 时钟
- (4) 停止子系统时钟

# (1) XT1 时钟振荡时设置过程示例

<1> 设置 XT1 和 XT2 引脚并选择操作模式 (PCC 和 OSCCTL 寄存器)

当 XTSTART、EXCLKS 和 OSCSELS 设置为如下模式时,将从端口模式切换到 XT1 振荡模式。

| XTSTART | EXCLKS | OSCSELS | 子系统时钟引脚操作<br>模式 | P123/XT1 引脚 | P124/XT2/<br>EXCLKS 引脚 |
|---------|--------|---------|-----------------|-------------|------------------------|
| 0       | 0      | 1       | XT1 振荡模式        | 连接晶体/陶瓷振荡器  | 목                      |
| 1       | ×      | ×       |                 |             |                        |

**备注:** ×: 不必考虑

### <2> 等待子系统时钟振荡稳定

使用定时器功能, 通过软件等待子系统时钟振荡稳定时间。

注意事项: 在子系统时钟运行时,不要改变 XTSTART, EXCLKS 和 OSCSELS 的值。

# (2) 使用外部子系统时钟时设置过程示例

<1> 设置 XT1 和 XT2 引脚,选择 XT1 时钟/外部时钟和控制振荡 (PCC 和 OSCCTL 寄存器) 当 XTSTART 清零并且 EXCLKS 和 OSCSELS 置 1 时,将从端口模式切换到外部时钟输入模式。在这种情况下,将外部时钟输入到 EXCLKS/XT2/P124 引脚。

| XTSTART | EXCLKS | OSCSELS | 子系统时钟引脚操作<br>模式 | P123/XT1 引脚 | P124/XT2/<br>EXCLKS 引脚 |
|---------|--------|---------|-----------------|-------------|------------------------|
| 0       | 1      | 1       | 外部时钟输入模式        | I/O 端口      | 外部时钟输入                 |

注意事项:在子系统时钟运行时,不要改变 XTSTART, EXCLKS 和 OSCSELS 的值。

### (3) 使用子系统时钟作为 CPU 时钟时设置过程示例

<1> 设置子系统时钟振荡\*\*

(参见 6.6.3 (1) XT1 时钟振荡时设置过程示例和 (2) 使用外部子系统时钟时设置过程示例。)

注: 当子系统时钟已经运行时,不需要设置<1>。

### <2> 切换 CPU 时钟(PCC 寄存器)

CSS 置 1 时,子系统时钟提供给 CPU。

| CSS | PCC2 | PCC1 | PCC0 | CPU 时钟 (fcpu) 选择 |
|-----|------|------|------|------------------|
| 1   | 0    | 0    | 0    | fsuB/2           |
|     | 0    | 0    | 1    |                  |
|     | 0    | 1    | 0    |                  |
|     | 0    | 1    | 1    |                  |
|     | 1    | 0    | 0    |                  |
|     |      | 其他情况 |      | 禁止设置             |

### (4) 停止子系统时钟时设置过程示例

<1> 确认 CPU 时钟状态(PCC 和 MCM 寄存器)

根据 CLS 和 MCS 确认 CPU 没有使用子系统时钟。

当 CLS = 1 时, CPU 采用子系统时钟, 因此将 CPU 时钟切换为内部高速振荡时钟或高速系统时钟。

| CLS | MCS | CPU 时钟状态 |
|-----|-----|----------|
| 0   | 0   | 内部高速振荡时钟 |
| 0   | 1   | 高速系统时钟   |
| 1   | ×   | 子系统时钟    |

# <2> 停止子系统时钟 (OSCCTL 寄存器)

OSCSELS 清零时,停止 XT1 振荡(禁止外部时钟输入)。

注意事项: 1.清零 OSCSEL 时,必须确认 CLS = 0。此外,如果钟表定时器使用子系统时钟,则应停止其操作。

2. 子系统时钟振荡不能通过使用 STOP 指令来停止。

### 6.6.4 控制内部低速振荡时钟示例

内部低速振荡时钟不能用作 CPU 时钟。 只有如下外部硬件可以使用这个时钟。

- 看门狗定时器
- •8位定时器 H1(选择 fRL 作为计数时钟时)

此外,可以通过选项字节选择如下操作模式。

- 内部低速振荡器不能停止
- 内部低速振荡器可由软件停止

在复位释放后内部低速振荡器自动开始振荡,并且如果通过选项字节允许看门狗定时器操作,则驱动看门狗定时器 (240 kHz (TYP.))。

# (1) 停止内部低速振荡时钟时设置过程示例

<1> 将 LSRSTOP 置 1 (RCM 寄存器)
LSRSTOP 置 1 时,停止内部低速振荡时钟。

# (2) 内部低速振荡时钟重新振荡时设置过程示例

<1> LSRSTOP 清零 (RCM 寄存器) LSRSTOP 清零时,内部低速振荡时钟重新振荡。

注意事项:如果通过选项字节选择"不能停止内部低速振荡器",则不能控制内部低速振荡时钟的振荡。

### 6.6.5 CPU 和外部硬件所采用的时钟

下表显示了CPU和外部硬件采用的时钟之间的关系及寄存器的设置。

# 表 6-4 CPU 和外部硬件采用的时钟及寄存器设置

| 时钟       |               | XSEL | CSS | МСМ0 | EXCLK |
|----------|---------------|------|-----|------|-------|
| CPU 时钟   | CPU 时钟 外部硬件时钟 |      |     |      |       |
| 内部高速振荡时钟 |               | 0    | 0   | ×    | ×     |
| 内部高速振荡时钟 | X1 时钟         | 1    | 0   | 0    | 0     |
|          | 外部主系统时钟       | 1    | 0   | 0    | 1     |
| X1 时钟    | 1             | 0    | 1   | 0    |       |
| 外部主系统时钟  |               | 1    | 0   | 1    | 1     |
| 子系统时钟    | 内部高速振荡时钟      | 0    | 1   | ×    | ×     |
|          | X1 时钟         | 1    | 1   | 0    | 0     |
|          |               | 1    | 1   | 1    | 0     |
|          | 外部主系统时钟       | 1    | 1   | 0    | 1     |
|          |               | 1    | 1   | 1    | 1     |

**备注:** 1. XSEL: 主时钟模式寄存器(MCM)的第 2 位

2. CSS: 处理器时钟控制寄存器(PCC)的第 4 位

3. MCM0: MCM 的第 0 位

4. EXCLK: 时钟操作模式选择寄存器(OSCCTL)的第7位

**5.** ×: 不必考虑

### 6.6.6 CPU 时钟状态转换图

图 6-14 显示了该产品 CPU 时钟状态转换图。

图 6-14 CPU 时钟状态转换图 (设置 1.59 V POC 模式 (选项字节: POCMODE = 0))



★ **备注:** 在 2.7 V/1.59 V POC 模式下 (选项字节: POCMODE = 1), 当供电电压超过 2.7V(TYP.)时 CPU 时钟状态 转换为上图所示的(A), 而在复位处理后(20 μs (TYP.))变到(B)。

表 6-5 显示了 CPU 时钟的切换过程与 SFR 寄存器设置示例

# 表 6-5. CPU 时钟切换与 SFR 寄存器设置示例(1/4)

# (1) 复位释放后(A)CPU 使用内部高速振荡时钟(B)

| 状态转换                  | SFR 寄存器设置                |  |
|-----------------------|--------------------------|--|
| $(A) \rightarrow (B)$ | SFR 寄存器不必设置 (复位释放后默认状态). |  |

# (2) 复位释放后(A)CPU 使用高速系统时钟(C)

(复位释放后 CPU 立即使用内部高速振荡时钟(B)。)

(SFR 寄存器设置序列) ————

| SFR 寄存器设置标志<br>状态转换                            | AMPH | EXCLK | OSCSEL | MSTOP | OSTC<br>寄存器 | XSEL | МСМ0 |
|------------------------------------------------|------|-------|--------|-------|-------------|------|------|
| (A) → (B) → (C) (X1 时钟: 1 MHz ≤ fxн ≤ 10 MHz)  | 0    | 0     | 1      | 0     | 必须检测        | 1    | 1    |
| (A) → (B) → (C) (外部主时钟: 1 MHz ≤ fxн ≤ 10 MHz)  | 0    | 1     | 1      | 0     | 不必检测        | 1    | 1    |
| (A) → (B) → (C) (X1 时钟: 10 MHz < fxн ≤ 20 MHz) | 1    | 0     | 1      | 0     | 必须检测        | 1    | 1    |
| (A) → (B) → (C) 外部主时钟: 10 MHz < fxн ≤ 20 MHz)  | 1    | 1     | 1      | 0     | 不必检测        | 1    | 1    |

注意事项: 供电电压达到所用时钟的操作电压后,设置时钟(参见第三十章 电子产品规范(目标))。

# ★ (3) 复位释放后(A)CPU 使用子系统时钟(D)

(SFR 寄存器设置序列) —

| SFR 寄存器设置标志               | XTSTART | EXCLKS | OSCSELS | 等待振荡稳定 | CSS |
|---------------------------|---------|--------|---------|--------|-----|
| 状态转换                      |         |        |         |        |     |
| (A) → (B) → (D) (XT1 时钟)  | 0       | 0      | 1       | 必须     | 1   |
|                           | 1       | ×      | ×       |        |     |
| (A) → (B) → (D) (外部子系统时钟) | 0       | 1      | 1       | 不必要    | 1   |

**备注:** 1. 表 6-5 的(A) 到 (I)对应图 6-14 的(A)到(I)。

2. EXCLK, OSCSEL, EXCLKS, OSCSELS, AMPH:

时钟操作模式选择寄存器(OSCCTL)的第7位到第4位与第0位

MSTOP: 主 OSC 控制寄存器(MOC)的第7位

 XSEL, MCM0:
 主时钟模式寄存器(MCM)的第 2 位与第 0 位

 XTSTART, CSS:
 处理器时钟控制寄存器(PCC)的第 6 位与第 4 位

×: 不必考虑

# 表 6-5. CPU 时钟切换与 SFR 寄存器设置示例(2/4)

# ★ (4) CPU 时钟从内部高速振荡时钟(B)切换到高速系统时钟(C)

(SFR 寄存器的设置顺序) ——

| SFR 寄存器的设置标志                                                  | AMPH <sup>≇</sup> | EXCLK | OSCSEL | MSTOP | OSTC | XSEL** | МСМ0 |
|---------------------------------------------------------------|-------------------|-------|--------|-------|------|--------|------|
| 状态转换                                                          |                   |       |        |       | 寄存器  |        |      |
| (B) $\rightarrow$ (C) (X1 时钟: 1 MHz $\leq$ fxH $\leq$ 10 MHz) | 0                 | 0     | 1      | 0     | 必须检测 | 1      | 1    |
| (B) → (C) (外部主时钟: 1 MHz ≤ fxн ≤ 10 MHz)                       | 0                 | 1     | 1      | 0     | 不必检测 | 1      | 1    |
| (B) → (C) (X1 时钟: 10 MHz < fxн ≤ 20 MHz)                      | 1                 | 0     | 1      | 0     | 必须检测 | 1      | 1    |
| (B) → (C) (外部主时钟: 10 MHz < fxн ≤ 20 MHz)                      | 1                 | 1     | 1      | 0     | 不必检测 | 1      | 1    |

如果这些寄存器已设置则不必要 如果 CPU 使用高速 系统时钟则不必要

注: 复位释放后该标志只能被修改一次。如果已经设置了该项,则无需再设置。

注意事项:供电电压达到所用时钟的操作电压后,设置时钟(参见第三十章 电子产品规范(目标))。

### ★ (5) CPU 时钟从内部高速振荡时钟(B)切换到子系统时钟(D)

(SFR 寄存器的设置顺序) 一

| 状态转换 (B) → (D) (XT1 时钟)  0 0 1 必须 1  1 × ×  (B) → (D) (外至子系統財钟)  0 1 7 必要 1 | SFR 寄存器的设置标志        | XTSTART | EXCLKS | OSCSELS | 等待振荡稳定 | CSS |
|-----------------------------------------------------------------------------|---------------------|---------|--------|---------|--------|-----|
| 1 × ×                                                                       | 状态转换                |         |        |         |        |     |
|                                                                             | (B) → (D) (XT1 时钟)  | 0       | 0      | 1       | 必须     | 1   |
| (B) → (D) (外部子系统时钟) 0 1 1 不必更 1                                             |                     | 1       | ×      | ×       |        |     |
|                                                                             | (B) → (D) (外部子系统时钟) | 0       | 1      | 1       | 不必要    | 1   |

如果 CPU 使用子系统时钟则不必要

**备注:** 1. 表 6-5 的(A) 到 (I)对应图 6-14 的(A)到(I)。

2. EXCLK, OSCSEL, EXCLKS, OSCSELS, AMPH:

时钟操作模式选择寄存器(OSCCTL)的第7位到第4位与第0位

MSTOP: 主 OSC 控制寄存器(MOC)的第7位

XSEL, MCM0: 主时钟模式寄存器(MCM)的第 2 位与第 0 位 XTSTART, CSS: 处理器时钟控制寄存器(PCC)的第 6 位与第 4 位

×: 不必考虑

# 表 6-5 CPU 时钟切换与 SFR 寄存器设置示例 (3/4)

# (6) CPU 时钟从高速系统时钟(C)切换到内部高速振荡时钟(B)

(SFR 寄存器的设置顺序) —

|                       | (01代 旬刊 冊 印 及 五/校/1) |       |         |      |
|-----------------------|----------------------|-------|---------|------|
|                       | SFR 寄存器的设置标志         | RSTOP | RSTS    | MCM0 |
| 状态转换                  |                      |       |         |      |
| $(C) \rightarrow (B)$ |                      | 0     | 确认该标志为1 | 0    |
|                       |                      | (     | ,       |      |

如果 CPU 使用内部高速振荡时钟则不必要

### (7) CPU 时钟从高速系统时钟(C)切换到子系统时钟(D)

(SFR 寄存器的设置顺序)

| SFR 寄存器的设置标志        | XTSTART | EXCLKS | OSCSELS | 等待振荡稳定 | CSS |
|---------------------|---------|--------|---------|--------|-----|
| 状态转换                |         |        |         |        |     |
| (C) → (D) (XT1 时钟)  | 0       | 0      | 1       | 必须     | 1   |
|                     | 1       | ×      | ×       |        |     |
| (C) → (D) (外部子系统时钟) | 0       | 1      | 1       | 不必要    | 1   |

如果 CPU 使用子系统时钟则不必要

### (8) CPU 时钟从子系统时钟(D)切换到内部高速振荡时钟(B)

 (SFR 寄存器的设置序列)

 SFR 寄存器的设置标志
 RSTOP
 RSTS
 MCM0
 CSS

 状态转换
 0
 确认该标志为1
 0
 0

如果 CPU 使用内部高速振荡时钟则不 如果 XSEL= 0 则 必要 不必要

**备注:** 1. 表 6-5 的(A) 到 (I)对应图 6-14 的(A)到(I)。

**2.** MCM0: 主时钟模式寄存器(MCM)的第 0 位

EXCLKS, OSCSELS: 时钟操作模式选择寄存器(OSCCTL)的第5位与第4位

 RSTS, RSTOP:
 内部振荡模式寄存器(RCM)的第7位和第0位

 XTSTART, CSS:
 处理器时钟控制寄存器(PCC)的第6位与第4位

×: 不必考虑

# 表 6-5 CPU 时钟切换与 SFR 寄存器设置示例 (4/4)

### ★ (9) CPU 时钟从子系统时钟(D)切换到高速系统时钟(C)

(SFR 寄存器的设置序列)

| SFR 寄存器的设置标志<br>状态转换                     | AMPH <sup>≇</sup> | EXCLK | OSCSEL | MSTOP | OSTC<br>寄存器 | XSEL* | МСМ0 | CSS |
|------------------------------------------|-------------------|-------|--------|-------|-------------|-------|------|-----|
| (D) → (C) (X1 时钟: 1 MHz ≤ fxн ≤ 10 MHz)  | 0                 | 0     | 1      | 0     | 必须检测        | 1     | 1    | 0   |
| (D) → (C) (外部主时钟: 1 MHz ≤ fxн ≤ 10 MHz   | 0                 | 1     | 1      | 0     | 不必检测        | 1     | 1    | 0   |
| (D) → (C) (X1 时钟: 10 MHz < fxн ≤ 20 MHz) | 1                 | 0     | 1      | 0     | 必须检测        | 1     | 1    | 0   |
| (D) → (C) (外部主时钟: 10 MHz < fxн ≤ 20 MHz) | 1                 | 1     | 1      | 0     | 不必检测        | 1     | 1    | 0   |

如果这些寄存器已设置则不必 如果 CPU 使用高速 如果寄存器已设置则不必要

系统时钟则不必要

注: 复位释放后该标志只能被修改一次。如果已经设置了该项,则无需再设置。

注意事项: 供电电压达到所用时钟的操作电压后,设置时钟(参见第三十章 电子产品规范(目标))。

- (10) ◆ CPU 使用内部高速振荡时钟(B)时 HALT 模式(E)的设置。
  - ◆ CPU 使用高速系统时钟(C)时 HALT 模式(F) 的设置。
  - CPU 使用子系统时钟(D)时 HALT 模式(G) 的设置。

| 状态转换                                                        | 设置         |
|-------------------------------------------------------------|------------|
| $ \begin{array}{c} (B) \to (E) \\ (C) \to (F) \end{array} $ | 执行 HALT 指令 |
| $(C) \rightarrow (F)$                                       |            |
| $(D) \rightarrow (G)$                                       |            |

- (11) ◆ CPU 使用内部高速振荡时钟(B)时 STOP 模式(H) 的设置。
  - CPU 使用高速系统时钟(C)时 STOP 模式(I) 的设置。

(设置顺序) -

| 状态转换                                                        | 设置                          |            |  |  |
|-------------------------------------------------------------|-----------------------------|------------|--|--|
| $ \begin{array}{c} (B) \to (H) \\ (C) \to (I) \end{array} $ | 停止那些不能在 STOP 模式下使用的<br>外部功能 | 执行 STOP 指令 |  |  |

备注:

1. 表 6-5 的(A) 到 (I)对应图 6-14 的(A)到(I)。

2. EXCLK, OSCSEL, AMPH: 时钟操作模式选择寄存器(OSCCTL)的第7,6和0位

MSTOP: 主 OSC 控制寄存器(MOC)的第7位

XSEL, MCM0: 主时钟模式寄存器(MCM)的第2位和第0位 CSS: 处理器时钟控制寄存器(PCC)的第 4 位

# 6.6.7 CPU 时钟切换之前的状况与切换之后的处理

CPU 时钟切换之前的状况与切换之后的处理显示如下。

#### $\star$

# 表 6-6 切换 CPU 时钟

| CPU                 | J时钟                                                             | 切换前的状况                                                                                  | 切换后的处理                                                                                                 |  |  |
|---------------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--|--|
| 切换前                 | 切换后                                                             | 1                                                                                       |                                                                                                        |  |  |
| 内部高速振荡时 钟           | X1 时钟                                                           | X1 振荡稳定  • MSTOP = 0, OSCSEL = 1, EXCLK = 0  • 经历了振荡稳定时间                                | <ul> <li>可以停止内部高速振荡器(RSTOP = 1).</li> <li>AMPH 被设置为 1 后 CPU 时钟停止 5 μs (MIN.)。</li> </ul>               |  |  |
|                     | 外部主系统时钟 允许来自 EXCLK 引脚的外部时钟输入 • MSTOP = 0, OSCSEL = 1, EXCLK = 1 |                                                                                         |                                                                                                        |  |  |
| X1 时钟               | 内部高速振荡时                                                         | 内部高速振荡器振荡                                                                               | 可以停止 X1 振荡(MSTOP = 1).                                                                                 |  |  |
| 外部主系统时钟             | 钟                                                               | • RSTOP = 0                                                                             | 可以禁止外部主系统时钟输入(MSTOP = 1).                                                                              |  |  |
| 内部高速振荡时<br>钟        | XT1 时钟                                                          | XT1 振荡稳定 • XTSTART = 0, EXCLKS = 0,                                                     | 通过停止内部高速振荡器可以降低操作电流<br>(RSTOP = 1)                                                                     |  |  |
| X1 时钟               |                                                                 | OSCSELS = 1 或 XTSTART = 1                                                               | 可以停止 X1 振荡 (MSTOP = 1)                                                                                 |  |  |
| 外部主系统时钟             |                                                                 | • 经历了振荡稳定时间                                                                             | 可以禁止外部主系统时钟输入(MSTOP = 1)                                                                               |  |  |
| 内部高速振荡时<br>钟        |                                                                 | 允许来自 EXCLK 引脚的外部时钟输入 • XTSTART = 0, EXCLKS = 1,                                         | 通过停止内部高速振荡器可以降低操作电流<br>(RSTOP = 1).                                                                    |  |  |
| X1 时钟               |                                                                 | OSCSELS = 1                                                                             | 可以停止 X1 振荡(MSTOP = 1).                                                                                 |  |  |
| 外部主系统时钟             |                                                                 |                                                                                         | 可以禁止外部主系统时钟输入(MSTOP = 1).                                                                              |  |  |
| XT1 时钟, 外部子<br>系统时钟 | 内部高速振荡时<br>钟                                                    | 内部高速振荡器振荡且选择内部高速振荡时<br>钟作为主系统时钟<br>• RSTOP = 0, MCS = 0                                 | 可停止 XT1 振荡或者禁止外部子系统时钟输入(OSCSELS = 0).                                                                  |  |  |
|                     | X1 时钟                                                           | X1 振荡稳定且选择高速系统时钟作为主系统<br>时钟  • MSTOP = 0, OSCSEL = 1, EXCLK = 0  • 经历了振荡稳定时间  • MCS = 1 | <ul> <li>可停止 XT1 振荡或者禁止外部子系统时钟输入(OSCSELS = 0).</li> <li>AMPH 被设置为 1 后 CPU 时钟停止 5 μs (MIN.)。</li> </ul> |  |  |
|                     | 外部主系统时钟                                                         | 允许来自 EXCLK 引脚的外部时钟输入 并选择高速系统时钟作为主系统时钟  • MSTOP = 0, OSCSEL = 1, EXCLK = 1  • MCS = 1    |                                                                                                        |  |  |

### ★ 6.6.8 CPU 时钟和主系统时钟切换所需的时间

通过设置处理器时钟控制器(PCC)的第 0 位到第 2 位(PCC0 到 PCC2)以及第 4 位(CSS),可以切换 CPU 时钟(在主系统时钟和子系统时钟之间),同时可以改变主系统时钟的分频比。

修改 PCC 后,实际的切换操作不会立即执行;使用切换前的时钟继续操作几个时钟(见表 6-7)。

可以通过 PCC 寄存器的第5位(CLS)来确定 CPU 使用主系统时钟还是子系统时钟。

|     |      |      |      |     |        | <b>なることは何の次//  間間は1回り上が過程が</b> |      |                |       |      |      |      |      |      |      |     |        |               |      |     |      |              |      |     |        |      |      |
|-----|------|------|------|-----|--------|--------------------------------|------|----------------|-------|------|------|------|------|------|------|-----|--------|---------------|------|-----|------|--------------|------|-----|--------|------|------|
| 切   | 换前   | 设置   | 值    |     | 切换后设置值 |                                |      |                |       |      |      |      |      |      |      |     |        |               |      |     |      |              |      |     |        |      |      |
| CSS | PCC2 | PCC1 | PCC0 | CSS | PCC2   | PCC1                           | PCC0 | CSS            | PCC2  | PCC1 | PCC0 | CSS  | PCC2 | PCC1 | PCC0 | CSS | PCC2   | PCC1          | PCC0 | CSS | PCC2 | PCC1         | PCC0 | CSS | PCC2   | PCC1 | PCC0 |
|     |      |      |      | 0   | 0      | 0                              | 0    | 0              | 0     | 0    | 1    | 0    | 0    | 1    | 0    | 0   | 0      | 1             | 1    | 0   | 1    | 0            | 0    | 1   | ×      | ×    | ×    |
| 0   | 0    | 0    | 0    |     |        |                                |      |                | 16 个  | ·时钟  | ı    |      | 16 个 | ·时钟  |      |     | 16 个   | 时钟            |      |     | 16 个 | 时钟           | ı    | 2fx | r/fsue | 个时   | 钟    |
|     | 0    | 0    | 1    |     | 8个时钟   |                                |      | 8个时钟 8个时钟 8个时钟 |       |      |      |      | 8个   | 时钟   |      | fxr | -/fsub | 个时            | 钟    |     |      |              |      |     |        |      |      |
|     | 0    | 1    | 0    |     | 4个时钟   |                                | 4个时钟 |                |       |      | _    |      | /    |      | 4个   | 时钟  |        |               | 4个   | 时钟  |      | fxp/2fsua个时钟 |      | 钟   |        |      |      |
|     | 0    | 1    | 1    |     | 2个时钟   |                                | 2个时钟 |                | 2个时钟  |      |      |      |      | /    | 2个时钟 |     |        | fxp/4fsus 个时钟 |      | 钟   |      |              |      |     |        |      |      |
|     | 1    | 0    | 0    |     | 1个时钟   |                                | 1个时钟 |                | 1 个时钟 |      |      | 1个时钟 |      |      |      |     |        | fxp/8fsua个时钟  |      | 钟   |      |              |      |     |        |      |      |
| 1   | ×    | ×    | ×    |     | 2个     | 时钟                             |      |                | 2个    | 时钟   |      |      | 2个   | 时钟   |      |     | 2个     | 时钟            |      |     | 2个   | 时钟           |      |     | _      | _    | _    |

表 6-7 CPU 时钟切换所需时间与主系统时钟周期分频因子

注意事项:主系统时钟周期分频因子(PCC0 到 PCC2)的选择,以及从主系统时钟到子系统时钟的切换(CSS 从 0 变 到 1)不能同时设置。

但对于主系统时钟周期分频因子(PCC0 到 PCC2)的选择,以及子系统时钟到主系统时钟的切换(CSS 从 1 变到 0)可以同时设置。

- **备注:** 1. 表 6-7 列出的时钟数是切换前的 CPU 时钟数。
  - **2.** 将 CPU 时钟从子系统时钟切换到主系统时钟,可通过舍入一个时钟并舍弃小数部分来计算时钟数量(如下所示)。

**示例:** 将 CPU 时钟从 fsub/2 切换到 fxp/2 (@ 振荡频率 fsub = 32.768 kHz, fxp = 10 MHz) fxp/fsub =  $10000/32.768 \cong 305.1 \rightarrow 306$  个时钟

通过设置主时钟模式寄存器(MCM)的第 0 位(MCM0),可以切换主系统时钟(在内部高速振荡时钟和高速系统时钟之间)。

修改 MCM0 后,实际的切换操作不会立即执行;使用切换前的时钟继续操作几个时钟(见表 6-8)。可以通过 MCM 寄存器的第 1 位(MCS)来确定 CPU 使用内部高速振荡时钟还是高速系统时钟。

表 6-8 主系统时钟切换所需的最长时间

| 切换前设置值 | 切换后             | 设置值            |  |  |  |
|--------|-----------------|----------------|--|--|--|
| MCM0   | МСМО            |                |  |  |  |
|        | 0               | 1              |  |  |  |
| 0      |                 | 1 + 2frн/fxн时钟 |  |  |  |
| 1      | 1 + 2fxн/frн 时钟 |                |  |  |  |

注意事项: 当内部高速振荡时钟切换到高速系统时钟时, MCM 的第 2 位(XSEL)必须预先被设置为 1。 XSEL 值在复位释放后只能被修改一次。

**备注:** 1. 表 6-8 所列时钟数是切换之前的主系统时钟数。

2. 通过舍去小数部分,计算表 6-8 的时钟数。

**示例:** 将主系统时钟从内部高速振荡时钟切换到高速系统时钟(@振荡频率 frH = 8 MHz, fxH = 10 MHz)

 $1 + 2f_{RH}/f_{XH} = 1 + 2 \times 8/10 = 1 + 2 \times 0.8 = 1 + 1.6 = 2.6 \rightarrow 2$ 个时钟

# ★ 6.6.9 时钟振荡停止前的状况

下表列出了停止时钟振荡的寄存器标志位设置(禁止外部时钟输入)和时钟振荡停止前的状况。

表 6-9 时钟振荡停止前的状况及标志位设置

| 时钟       | 时钟振荡停止前的状况 (禁止外部时钟输入)                  | SFR 寄存器的标志位<br>设置 |
|----------|----------------------------------------|-------------------|
| 内部高速振荡时钟 | MCS = 1 或 CLS = 1<br>(CPU 不使用内部高速振荡时钟) | RSTOP = 1         |
| X1 时钟    | MCS = 1 或 CLS = 1                      | MSTOP = 1         |
| 外部主系统时钟  | (CPU 不使用高速系统时钟)                        |                   |
| XT1 时钟   | CLS = 0                                | OSCSELS = 0       |
| 外部子系统时钟  | (CPU 不使用子系统时钟)                         |                   |

# ★ 6.6.10 外部硬件与源时钟

下表列出了 78K0/KF2 中包含的外部硬件与源时钟。

表 6-10 外部硬件与源时钟

| 源时钟      |       | 外部硬件时钟<br>(fprs) | 子系统时钟 (fsua) | 内部低速振荡时钟<br>(fr.L) | TM50 输出 | 来自外部硬件引脚 的外部时钟                      |
|----------|-------|------------------|--------------|--------------------|---------|-------------------------------------|
| 外部硬件     |       | (IFRS)           |              | (IKL)              |         | H3>1 H4+3 11                        |
| 16 位定时器/ | 00    | Y                | N            | N                  | N       | Y (TI000 引脚) <sup>推</sup>           |
| 事件计数器    | 01    | Y                | N            | N                  | N       | Y (TI001 引脚) <sup>建</sup>           |
| 8位定时器/   | 50    | Υ                | N            | N                  | N       | Y (TI50 引脚)**                       |
| 事件计数器    | 51    | Y                | N            | N                  | N       | Y (TI51 引脚) <sup>推</sup>            |
| 8位定时器    | H0    | Υ                | N            | N                  | Y       | N                                   |
|          | H1    | Υ                | N            | Y                  | N       | N                                   |
| 钟表定时器    |       | Υ                | Υ            | N                  | N       | N                                   |
| 看门狗定时器   |       | N                | N            | Y                  | N       | N                                   |
| 蜂鸣器输出    |       | Υ                | N            | N                  | N       | N                                   |
| 时钟输出     |       | Υ                | Υ            | N                  | N       | N                                   |
| A/D 转换器  |       | Υ                | N            | N                  | N       | N                                   |
| 串行接口     | UART0 | Υ                | N            | N                  | Υ       | N                                   |
|          | UART6 | Υ                | N            | N                  | Υ       | N                                   |
|          | CSI10 | Υ                | N            | N                  | N       | Y (SCK10 引脚) <sup>推</sup>           |
|          | CSI11 | Υ                | N            | N                  | N       | Y (SCK11 引脚) <sup>推</sup>           |
|          | CSIA0 | Υ                | N            | N                  | N       | Y (SCKA0 引脚)**                      |
|          | IIC0  | Υ                | N            | N                  | N       | Y (EXSCL0,<br>SCL0 引脚) <sup>推</sup> |

**注:** 当 CPU 使用子系统时钟且内部高速振荡时钟已经停止时,不要启动依赖由外部硬件引脚输入外部时钟的这些功能。

**备注:** Y: 可选, N: 不可选

# 第七章 16 位定时器/事件计数器 00 和 01

# 7.1 16 位定时器/事件计数器 00 和 01 的功能

16 位定时器/事件计数器 00 和 01 具有以下功能。

# (1) 间隔定时器

16 位定时器/事件计数器 00 和 01 以预置的时间间隔产生中断请求。

# (2) 方波输出

16 位定时器/事件计数器 00 和 01 可以输出任选频率的方波。

# (3) 外部事件计数器

16 位定时器/事件计数器 00 和 01 可以测量外部输入信号的脉冲数。

# (4) 单脉冲输出

16 位定时器/事件计数器 00 和 01 可以输出任意脉冲宽度的单脉冲。

# (5) PPG 输出

16 位定时器/事件计数器 00 和 01 可以输出矩形波,矩形波的频率和输出宽度可以自由设置。

# (6) 脉冲宽度测量

16 位定时器/事件计数器 00 和 01 可以测量外部输入信号的脉冲宽度。

# 7.2 16 位定时器/事件计数器 00 和 01 的配置

16 位定时器/事件计数器 00 和 01 包括以下硬件。

表 7-1 16 位定时器/事件计数器 00 和 01 的配置

| 项目      | 配置                                                                                                                                 |
|---------|------------------------------------------------------------------------------------------------------------------------------------|
| 定时器/计数器 | 16 位定时器计数器 0n (TM0n)                                                                                                               |
| 寄存器     | 16 位定时器捕捉/比较寄存器 00n, 01n (CR00n, CR01n)                                                                                            |
| 定时器输入   | TI00n, TI01n 引脚                                                                                                                    |
| 定时器输出   | TO0n 引脚, 输出控制器                                                                                                                     |
| 控制寄存器   | 16 位定时器模式控制寄存器 On (TMCOn) 16 位定时器捕捉/比较控制寄存器 On (CRCOn) 16 位定时器输出控制寄存器 On (TOCOn) 预分频器模式寄存器 On (PRMOn) 端口模式寄存器 0 (PMO) 端口寄存器 0 (PO) |

备注: n = 0, 1

图 7-1 和 7-2 显示了 16 位定时器/事件计数器的框图。

内部总线 捕捉/比较控制 寄存器 00 (CRC00) CRC002 CRC001 CRC000 至 CR010 ► INTTM000 噪音 16 位定时器捕捉/比较 鉛 消除 TI010/TO00/P01 @-寄存器 000 (CR000) 器 匹配 **f**PRS fprs/22 16 位定时器计数器 00 fprs/28 清零 (TM00) 输出 \_⊚ TO00/TI010/ P01 控制器 噪音 匹配 消除 2 **f**PRS 输出锁存 器(P01) PM01 器 噪音 16 位定时器捕捉/比较 TI000/P00 ⊚ 消除 寄存器 010 (CR010) 器 ► INTTM010 CRC002 PRM001 PRM000 TMC003 TMC002 TMC001 OVF00 OSPT00 OSPE00 TOC004 LVS00 LVR00 TOC001 TOE00 16 位定时器模式 控制寄存器 00 (TMC00) 16 位定时器输出 控制寄存器 00 (TOC00) 预分频器模式 寄存器 00 (PRM00) 内部总线

图 7-1 16 位定时器/事件计数器 00 的框图



图 7-2 16 位定时器/事件计数器 01 的框图

# (1) 16 位定时器计数器 0n (TM0n)

TM0n 是 16 位只读寄存器,用于脉冲计数。

计数器随计数时钟的上升沿次数同步增加。

如果在操作期间读取计数值,暂时停止计数时钟输入,则此时的计数值被读取。

### 备注: n= 0, 1

# 图 7-3 16 位定时器计数器 0n (TM0n)的格式



当 16 位定时器模式控制寄存器 0n (TMC0n)的第 3 和 2 位不是 00 时,可通过读取 TM0n 来获取计数值。如果在 TMC0n3 和 TMC0n2 = 00 时读取 TM0n,则获取的计数值为 0000H。 如出现以下情况,计数值复位为 0000H。

- 复位信号的产生
- TMC0n3 和 TMC0n2 被清零
- 在 TI00n 引脚输入有效沿产生清零和启动模式下, TI00n 引脚输入有效沿时
- 在 TMOn 和 CR00n 匹配时产生清零和启动模式下,如果 TM0n 和 CR00n 匹配时
- 在单脉冲输出模式下如果 OSPT0n 被设置为 1 或 TI00n 引脚输入有效沿时

### 注意事项: 1. 即使读取了 TM0n, 也不能通过 CR01n 捕捉到该值。

2. 读取 TM0n 时, 暂停计数时钟输入并在读取定时器后再恢复操作。因此不会出现时钟丢失。

# (2) 16 位定时器捕捉/比较寄存器 00n (CR00n), 16 位定时器捕捉/比较寄存器 01n (CR01n)

CR00n 与 CR01n 是 16 位寄存器, 具有捕捉或比较功能(通过 CRC0n 进行选择)。

当定时器停止操作时(TMC0n3 与 TMC0n2 = 00), 修改 CR00n 的值。

如果已按指定方式对 CR01n 进行设置,则在操作期间可以修改 CR01n。如需了解详细信息,可参见 **7.5.1 TM0n** 操作期间重写 CR01n。

可按 16 位读写这些寄存器。

复位信号的产生可将这些寄存器设置为 0000H。

### 备注: n = 0, 1

# 图 7-4 16 位定时器捕捉/比较寄存器 00n (CR00n)的格式



### (i) CR00n 用作比较寄存器

CR00n 的设置值与 16 位定时器计数器 0n (TM0n)的计数值频繁地相比较,如果匹配将产生一个中断请求 (INTTM00n)。在 CR00n 被重写前一直保持这个值。

### (ii) CR00n 用作捕捉寄存器

当输入捕捉触发时,TM0n的计数值被捕捉到CR00n。

可以使用 CRC0n 或 PRM0n 选择 Tl00n 引脚的反向脉冲沿或 Tl01n 引脚的有效沿作为捕捉触发。

### 图 7-5 16 位定时器捕捉/比较寄存器 01n (CR01n)的格式



# (i) CR01n 用作比较寄存器

CR01n 的设置值与 TM0n 的计数值频繁地相比较,如果匹配将产生一个中断请求(INTTM01n)。

### (ii) CR01n 用作捕捉寄存器

当输入捕捉触发时,TM0n的计数值被捕捉到CR00n。

可以选择 TI00n 引脚的有效沿作为捕捉触发。TI00n 有效沿由 PRM0n 来设置。

### 注意事项: 1. 如果要将该寄存器用作比较寄存器,则为 CR00n 和 CR01n 设置 0000H 以外的值。

- 2. 对于 P01 引脚, TI010 的有效沿和定时器输出(TO00)不能同时使用。对于 P06 引脚, TI011 的有效 沿和定时器输出(TO01)不能同时使用。可以任选其一。
- 3. 如果 16 位定时器模式控制寄存器 0n (TMC0n)的第 3 和 2 位(TMC0n3 和 TMC0n2)的清零(00)操作与捕捉触发输入冲突,则捕捉的数据不确定。
- 4. 如果要将捕捉模式转换为比较模式,必须先对 TMC0n3 与 TMC0n2 清零(00),然后再修改设置。 除非设备复位,否则一旦数值被捕捉,它将一直保存在 CR00n 中。如果已将模式转换为比较模式, 则必须设置比较值。
- 5. 如果设置为比较模式,则即使输入捕捉触发,CR00n/CR01n 也不执行捕捉操作。



表 7-2 CR00n 和 CR01n 的捕捉操作

注: CRC0n1 位的设置不会对 CR01n 的捕捉操作产生影响。

注意事项:如果要使用输入到 TI00n 引脚的反向脉冲沿来捕捉 TM0n 的计数值,并存入 CR00n,则在捕捉了计数 值后,不产生中断请求信号(INTTM00n)。如果在操作期间检测到 TI01n 的有效沿,则不执行捕捉操作,但会产生 INTTM00n 信号作为外部中断信号。当不使用外部中断时,可以屏蔽 INTTM00n 信号。

备注: 1. CRC0n1: 参见 7.3 (2) 捕捉/比较控制寄存器 0n (CRC0n) ES1n1, ES1n0, ES0n1, ES0n0: 参见 7.3 (4) 预分频器模式寄存器 0n (PRM0n)

**2.** n = 0, 1

# 7.3 控制 16 位定时器/事件计数器 00 和 01 的寄存器

控制 16 位定时器/事件计数器 00 和 01 的寄存器显示如下。

- 16 位定时器模式控制寄存器 0n (TMC0n)
- 捕捉/比较控制寄存器 0n (CRC0n)
- 16 位定时器输出控制寄存器 0n (TOC0n)
- 预分频器模式寄存器 0n (PRM0n)
- 端口模式寄存器 0 (PM0)
- 端口寄存器 0 (P0)

### (1) 16 位定时器模式控制寄存器 0n (TMC0n)

TMC0n 是一个 8 位寄存器,用于设置 16 位定时器操作模式、16 位定时器计数器 0n(TM0n)清零模式和输出定时,及溢出检测。

操作期间(当 TMC0n3 与 TMC0n2 不等于 00)禁止重写 TMC0n。当 TMC0n3 与 TMC0n2 清零(00) (停止操作)并且 OVF0n 也清零(0)时,可以修改它的值。

可以由1位或8位存储器操作指令设置。

复位信号的产生将 TMC0n 清零(00H)。

注意事项: 当设置 TMC0n2 与 TMC0n3 为 0, 0 (操作停止模式) 以外的值时, 16 位定时器计数器 0n (TM0n) 开始计数。若要停止操作,则设置 TMC0n2 和 TMC0n3 为 0, 0。

# 图 7-6 16 位定时器模式控制寄存器 00 (TMC00)的格式

| 地址: FFBAH | 复位后: | 00H R | /W |   |        |        |        |       |  |
|-----------|------|-------|----|---|--------|--------|--------|-------|--|
| 符号        | 7    | 6     | 5  | 4 | 3      | 2      | 1      | <0>   |  |
| TMC00     | 0    | 0     | 0  | 0 | TMC003 | TMC002 | TMC001 | OVF00 |  |

| TMC003 | TMC002 | 允许16位定时器/事件计数器00的操作                   |  |  |  |  |  |  |
|--------|--------|---------------------------------------|--|--|--|--|--|--|
| 0      | 0      | 禁止TM00的操作。停止供应操作时钟。异步复位内部电路           |  |  |  |  |  |  |
| 0      | 1      | 自由运行定时器模式                             |  |  |  |  |  |  |
| 1      | 0      | 通过TI000引脚有效沿输入进入 <sup>推</sup> 清零&启动模式 |  |  |  |  |  |  |
| 1      | 1      | TM00和CR000匹配时进入清零&启动模式                |  |  |  |  |  |  |

| TMC001 | 反转定时器输出(TO00)的条件                                                        |  |  |  |  |  |
|--------|-------------------------------------------------------------------------|--|--|--|--|--|
| 0      | TM00与CR000匹配或TM00与CR010匹配                                               |  |  |  |  |  |
| 1      | <ul><li>◆ TM00与CR000匹配或TM00与CR010匹配</li><li>◆ TI000引脚有效沿的触发输入</li></ul> |  |  |  |  |  |

| OVF00  | TM00溢出标志                               |  |  |  |  |  |
|--------|----------------------------------------|--|--|--|--|--|
| 清零 (0) | 清零 (0) 将OVF00清零(0)或 TMC003与TMC002 = 00 |  |  |  |  |  |
| 设置 (1) | 发生溢出                                   |  |  |  |  |  |

在所有操作模式下(自由运行定时器模式、清零&启动模式(通过TI000引脚有效沿输入进入)和清零&启动模式(在TM00与CR000匹配时进入))当TM00的值由FFFFH变为0000H时,OVF00标志位将被设置为1。 也可以将1写入OVF00进行设置。

注: 通过预分频器模式寄存器 00 (PRM00)的第5和4位(ES001, ES000)设置 TI000 引脚的有效沿。

# 图 7-7 16 位定时器模式控制寄存器 01 (TMC01)的格式

| 地址: FFB6H | 复位后: | 00H R | /W |   |        |        |        |       |
|-----------|------|-------|----|---|--------|--------|--------|-------|
| 符号        | 7    | 6     | 5  | 4 | 3      | 2      | 1      | <0>   |
| TMC01     | 0    | 0     | 0  | 0 | TMC013 | TMC012 | TMC011 | OVF01 |

| TMC013 | TMC012 | 允许16位定时器/事件计数器01的操作                  |  |  |  |  |  |
|--------|--------|--------------------------------------|--|--|--|--|--|
| 0      | 0      | 禁止TM01操作。 停止供应操作时钟。异步复位内部电路。         |  |  |  |  |  |
| 0      | 1      | 自由运行定时器模式                            |  |  |  |  |  |
| 1      | 0      | 过TI001引脚有效沿输入 <sup>推</sup> 进入清零&启动模式 |  |  |  |  |  |
| 1      | 1      | TM01与CR001匹配时进入清零&启动模式               |  |  |  |  |  |

| 反转定时器输出 (TO01)的条件                            |  |  |  |  |  |
|----------------------------------------------|--|--|--|--|--|
| 「M01与CR001匹配或TM01与CR011匹配                    |  |  |  |  |  |
| TM01与CR001匹配或TM01与CR011匹配<br>TI001脉冲有效沿的触发输入 |  |  |  |  |  |
| ٠ ٦                                          |  |  |  |  |  |

| OVF01  | TM01溢出标志                       |  |
|--------|--------------------------------|--|
| 清零 (0) | POVF01清零(0)或TMC013与TMC012 = 00 |  |
| 设置 (1) | 发生溢出                           |  |

在所有操作模式下(自由运行定时器模式、清零&启动模式(通过TI000引脚有效沿输入进入)和清零&启动模式(在TM00与CR000匹配时进入))当TM00的值由FFFFH变为0000H时,OVF00标志位将被设置为1。也可以将1写入OVF00进行设置。

注: 通过预分频器模式寄存器 01 (PRM01)的第5和4位(ES011, ES010)设置 TI001 引脚有效沿。

# (2) 捕捉/比较控制寄存器 0n (CRC0n)

CRC0n 用于控制 CR00n 与 CR01n 的操作。

操作期间(TMC0n3 与 TMC0n2 不等于 00 时)禁止修改 CRC0n。

可以由 1 位或 8 位存储器操作指令设置 CRC0n。

复位信号的产生将 CRC0n 清零(00H)。

备注: n = 0, 1

图 7-8 捕捉/比较控制寄存器 00 (CRC00)的格式

地址: FFBCH 复位后: 00H R/W 符号 2 0 4 3 1 CRC001 CRC00 0 0 0 0 0 CRC002 CRC000

| CRC002 | CR010 操作模式的选择 |  |  |  |
|--------|---------------|--|--|--|
| 0      | 用作比较寄存器       |  |  |  |
| 1      | 用作捕捉寄存器       |  |  |  |

| CRC001                                                                                         | CR000 捕捉触发选择                      |  |  |
|------------------------------------------------------------------------------------------------|-----------------------------------|--|--|
| 0                                                                                              | 在 TI010 引脚的有效沿捕捉                  |  |  |
| 1                                                                                              | 在 TI000 引脚的有效沿反向 <sup>唯</sup> 时捕捉 |  |  |
| 由 PRM00 设置 TI010 与 TI000 引脚的有效沿 如果在 CRC001=1 时将 ES001 和 ES000 设置为 11(两种脉冲沿),则不能检测 TI000 引脚的有效沿 |                                   |  |  |

| CRC000                                                                       | CR000 操作模式选择 |  |  |  |
|------------------------------------------------------------------------------|--------------|--|--|--|
| 0                                                                            | 用作比较寄存器      |  |  |  |
| 1 用作捕捉寄存器                                                                    |              |  |  |  |
| 如果 TMC003 与 TMC002 被设置为 11 (清零&启动模式(在 TM00 与 CR000 匹配时进入)),则必须将 CRC000 设置为 0 |              |  |  |  |

注: 当检测到 TI000 的有效沿时,不执行捕捉操作,但产生 INTTM000 信号作为外部中断信号。

注意事项: 为确保捕捉操作正确执行,捕捉触发需要的脉冲应大于两个计数时钟的时钟周期,该计数时钟用预分频器 模式寄存器 00 (PRM00)选择。

# 图 7-9 CR01n 捕捉操作示例 (指定上升沿有效)



图 7-10 捕捉/比较控制寄存器 01 (CRC01) 的格式

 地址: FFB8H
 复位后: 00H
 R/W

 符号
 7
 6
 5
 4
 3
 2
 1
 0

 CRC01
 0
 0
 0
 0
 CRC012
 CRC011
 CRC010

| CRC012 | CR011 操作模式选择 |  |  |  |
|--------|--------------|--|--|--|
| 0      | 用作比较寄存器      |  |  |  |
| 1      | 用作捕捉寄存器      |  |  |  |

| CRC011 | CR001 捕捉触发选择                                                                                     |  |  |
|--------|--------------------------------------------------------------------------------------------------|--|--|
| 0      | 0 在 TI011 引脚的有效沿捕捉                                                                               |  |  |
| 1      | 在 TI000 引脚的有效沿反向 <sup>推</sup> 时捕捉                                                                |  |  |
|        | 由 PRM01 设置 TI011 和 TI001 引脚的有效沿 如果 CRC011=1 时 ES011 和 ES010 被设置为 11(兼有两种脉冲沿),则不能检测 TI001 引脚的有效沿。 |  |  |

| CRC010                                                               | CR001 操作模式选择 |  |
|----------------------------------------------------------------------|--------------|--|
| 0                                                                    | 用作比较寄存器      |  |
| 1                                                                    | 用作捕捉寄存器      |  |
| 如果 TMC013 和 TMC012 被设置为 11(TM01 与 CR001 匹配时进入清零&启动模式),则必须设置 CRC010=0 |              |  |

注: 当从 TI011 引脚检测到有效沿时,不执行捕捉操作但会产生 INTTM001 信号作为外部中断信号。

注意事项: 为确保捕捉操作能正确执行,捕捉触发需要的脉冲应大于两个计数时钟的时钟周期,该计数时钟用预分频模式寄存器 01(PRM01)选择 (参见图 7-9 CR01n 捕捉操作示例(指定上升沿有效)。

# (3) 16 位定时器输出控制寄存器 0n (TOC0n)

TOC0n 是一个 8 位寄存器,用于控制 TO0n 引脚输出。

仅当 OSPT0n 操作时才能重写 TOC0n(当 TMC0n3 与 TMC0n2 不等于 00)。操作期间禁止重写其它位。

但可以在定时器操作期间对 TOC0n4 进行重写,作为重写 CR01n 的一种方法(参见 **7.5.1 TM0n 操作期间 CR01n 的重写**)。

可以由 1 位或 8 位存储器操作指令设置 TOC0n。

复位信号的产生将 TOC0n 清零(00H)。

### 注意事项: 必须按以下步骤设置 TOC0n。

- <1> 设置 TOC0n4 与 TOC0n1 为 1。
- <2> 仅设置 TOE0n=1。
- <3> 设置 LVS0n 或 LVR0n 为 1。

# 图 7-11 16 位定时器输出控制寄存器 00 (TOC00) 的格式

地址: FFBDH 复位后: 00H R/W

符号 TOC00

| 7 | <6>    | <5>    | 4      | <3>   | <2>   | 1      | <0>   |
|---|--------|--------|--------|-------|-------|--------|-------|
| 0 | OSPT00 | OSPE00 | TOC004 | LVS00 | LVR00 | TOC001 | TOE00 |

| OSPT00 | 通过软件进行单脉冲输出触发 |
|--------|---------------|
| 0      | -             |
| 1      | 单脉冲输出         |

该位的读取值总是为"0"。在所有模式下(单脉冲输出模式除外),不要将该位设置为 1。 如果该位为 1,则将 TM00 清零并启动。

| OSPE00 | 单脉冲输出操作控制       |  |  |  |
|--------|-----------------|--|--|--|
| 0      | <b>生续脉冲输出模式</b> |  |  |  |
| 1      | 单脉冲输出           |  |  |  |

在自由运行定时器模式或清零&启动模式(通过 TI000 引脚有效沿输入进入)下,单脉冲输出可以正确进行。 在清零&启动模式(由 TM00 与 CR000 匹配进入)下不能输出单脉冲。

| TOC004   | CR010 与 TM00 匹配时 TO00 引脚输出控制      |  |  |
|----------|-----------------------------------|--|--|
| 0        | 禁止反转操作                            |  |  |
| 1        | 允许反转操作                            |  |  |
| 即使 TOC00 | 即使 TOC004 = 0,也产生中断信号 (INTTM010)。 |  |  |

| LVS00 | LVR00 | TO00 引脚输出状态设置                       |  |
|-------|-------|-------------------------------------|--|
| 0     | 0     | 无变化                                 |  |
| 0     | 1     | TO00 引脚输出的初值为低电平 (将 TO00 引脚输出清零(0)) |  |
| 1     | 0     | TO00 引脚输出的初值为高电平 (将 TO00 引脚输出设置为 1) |  |
| 1     | 1     | 禁止设置                                |  |

- LVS00 与 LVR00 可以用来设置 TO00 引脚输出电平的初值。如果不必设初值,则将保持 LVS00 与 LVR00 为 00。
- 当 TOE00 = 1 时,必须设置 LVS00 与 LVR00。
   禁止同时将 LVS00、LVR00 和 TOE00 设置为 1。
- LVS00 与 LVR00 是触发位。通过将这两位设置为 1,可以对 TO00 引脚输出电平的初值进行设置。即使将这两位清零(0), TO00 引脚的输出也不会受到影响。
- LVS00 与 LVR00 的读取值总是为 0。
- 如需了解 LVS00 与 LVR00 的设置,参见 7.5.2 LVS0n 与 LVR0n 的设置。

| TOC001   | CR000 与 TM00 匹配时 TO00 引脚输出控制    |  |  |  |  |
|----------|---------------------------------|--|--|--|--|
| 0        | 禁止反转操作                          |  |  |  |  |
| 1        | 允许反转操作                          |  |  |  |  |
| 即使 TOC00 | 即使 TOC001 = 0,也产生中断信号(INTTM000) |  |  |  |  |

| TOE00 | TO00 引脚输出控制           |  |  |  |  |
|-------|-----------------------|--|--|--|--|
| 0     | 禁止输出 (TO00 引脚输出恒为低电平) |  |  |  |  |
| 1     | 允许输出                  |  |  |  |  |

# 图 7-12 16 位定时器输出控制寄存器 01 (TOC01) 的格式

地址: FFB9H 复位后: 00H R/W

符号 TOC01

| 7 | <6>    | <5>    | 4      | <3>   | <2>   | 1      | <0>   |
|---|--------|--------|--------|-------|-------|--------|-------|
| 0 | OSPT01 | OSPE01 | TOC014 | LVS01 | LVR01 | TOC011 | TOE01 |

| OSPT01                                     | 通过软件进行单脉冲输出触发 |  |  |
|--------------------------------------------|---------------|--|--|
| 0                                          | _             |  |  |
| 1                                          | 单脉冲输出         |  |  |
| 该位的读取值总是为"0"。在所有模式下(单脉冲输出模式除外),不要将该位设置为 1。 |               |  |  |

该位的读取值总是为"0"。在所有模式下(单脉冲输出模式除外),不要将该位设置为 1。 如果该位为 1,则将 TM00 清零并启动。

| OSPE01 | 单脉冲输出操作控制 |
|--------|-----------|
| 0      | 连续脉冲输出    |
| 1      | 单脉冲输出     |

在自由运行定时器模式或清零&启动模式(通过 TI001 引脚有效沿输入进入)下,单脉冲输出可以正确进行。 在清零&启动模式(由 TM01 与 CR001 匹配进入)下不能输出单脉冲。

| TOC014                           | CR011 与 TM01 匹配时 TO01 引脚输出控制 |  |  |  |
|----------------------------------|------------------------------|--|--|--|
| 0                                | 禁止反转操作                       |  |  |  |
| 1                                | 1 允许反转操作                     |  |  |  |
| 即使 TOC014 = 0 也产生中断信号 (INTTM011) |                              |  |  |  |

| LVS01 | LVR01 | TO01 引脚输出状态的设置                      |
|-------|-------|-------------------------------------|
| 0     | 0     | 无变化                                 |
| 0     | 1     | TO01 引脚输出的初值为低电平 (将 TO01 引脚输出清零(0)) |
| 1     | 0     | TO01 引脚输出的初值为高电平 (将 TO01 引脚输出设置为 1) |
| 1     | 1     | 禁止设置                                |

- LVS01 与 LVR01 可以用来设置 TO01 引脚输出电平的初值。如果不必设初值,则将保持 LVS01 与 LVR01 为 00。
- 当 TOE01 = 1 时必须设置 LVS01 与 LVR01。 禁止同时设置 LVS01、LVR01 和 TOE01。
- LVS01 与 LVR01 是触发位。通过将这两位设置为 1,可以对 TO01 引脚输出电平的初值进行设置。 即使将这两位清零(0), TO01 引脚的输出也不会受到影响。
- LVS01 与 LVR01 的读取值总是为 0。
- 如需了解 LVS01 与 LVR01 的设置,参见 7.5.2 LVS0n 与 LVR0n 的设置。

| TOC011   | CR001 与 TM01 匹配时 TO01 引脚输出控制      |  |  |  |  |
|----------|-----------------------------------|--|--|--|--|
| 0        | 禁止反转操作                            |  |  |  |  |
| 1        | 允许反转操作                            |  |  |  |  |
| 即使 TOC01 | 即使 TOC011 = 0, 也产生中断信号 (INTTM001) |  |  |  |  |

| TOE01 | TO01 引脚输出控制           |  |  |  |
|-------|-----------------------|--|--|--|
| 0     | 李止输出 (TO01 引脚输出恒为低电平) |  |  |  |
| 1     | 允许输出                  |  |  |  |

# (4) 预分频器模式寄存器 0n (PRM0n)

PRMOn 用于设置 16 位定时器计数器 On(TMOn)的计数时钟以及 TIOOn 与 TIO1n 引脚输入的有效沿。

操作期间(当 TMC0n3 与 TMC0n2 不等于 00)禁止重写 PRM0n。

可由 1 位或 8 位存储器操作指令设置 PRM0n。

复位信号的产生将 PRM0n 清零(00H)。

注意事项: 1. 当 PRM0n1 与 PRM0n0 为 11 时(指定 Tl00n 引脚的有效沿作为计数时钟),不要进行以下设置。

- 清零&启动模式(通过 TI00n 引脚有效沿进入)
- 设置 TI00n 引脚作为捕捉触发
- 2. 如果在 TI00n 或 TI01n 引脚为高电平并且指定 TI00n 或 TI01n 引脚的有效沿为上升沿或兼有两种脉冲沿时允许 16 位定时器/事件计数器 0n 操作,TI00n 或 TI01n 引脚的高电平将被检测为上升沿。当 TI00n 或 TI01n 引脚被上拉时要注意。然而一旦定时器操作已经被停止然后再次允许时则不检测上升沿。
- 3. 对于 P01 引脚, Tl010 的有效沿和定时器输出(TO00)不能同时使用,对于 P06 引脚, Tl011 的有效沿和定时器输出(TO01)也不能同时使用。可以任选其一。

图 7-13 预分频器模式寄存器 00 (PRM00) 的格式

地址: FFBBH 复位后: 00H R/W

符号 7 5 4 3 2 1 0 PRM00 ES101 ES100 ES001 ES000 0 0 PRM001 PRM000

| ES101 | ES100 | TI010 引脚有效沿选择 |
|-------|-------|---------------|
| 0     | 0     | 下降沿           |
| 0     | 1     | 上升沿           |
| 1     | 0     | 禁止设置          |
| 1     | 1     | 兼有上升沿和下降沿     |

| ES001 | ES000 | TI000 引脚有效沿选择 |
|-------|-------|---------------|
| 0     | 0     | 下降沿           |
| 0     | 1     | 上升沿           |
| 1     | 0     | 禁止设置          |
| 1     | 1     | 兼有上升沿和下降沿     |

| PRM001 | PRM000 | 计数时钟选择                 |              |              |               |               |
|--------|--------|------------------------|--------------|--------------|---------------|---------------|
|        |        |                        | fprs = 2 MHz | fprs = 5 MHz | fprs = 10 MHz | fprs = 20 MHz |
| 0      | 0      | fprs                   | 2 MHz        | 5 MHz        | 10 MHz        | 20 MHz        |
| 0      | 1      | fprs/2 <sup>2</sup>    | 500 kHz      | 1.25 MHz     | 2.5 MHz       | 5 MHz         |
| 1      | 0      | fprs/2 <sup>8</sup>    | 7.81 kHz     | 19.53 kHz    | 39.06 kHz     | 78.12 kHz     |
| 1      | 1      | TI000 有效沿 <sup>推</sup> |              |              |               |               |

注: 外部时钟脉冲宽度要求大于内部时钟(fprs)的两个周期宽度。

备注 fprs: 外围硬件时钟频率

# 图 7-14 预分频器模式寄存器 01 (PRM01) 的格式

地址: FFB7H 复位后: 00H R/W

 符号
 7
 6
 5
 4
 3
 2
 1
 0

 PRM01
 ES111
 ES110
 ES011
 ES010
 0
 0
 PRM011
 PRM010

| ES111 | ES110 | TI011 有效沿选择 |
|-------|-------|-------------|
| 0     | 0     | 下降沿         |
| 0     | 1     | 上升沿         |
| 1     | 0     | 禁止设置        |
| 1     | 1     | 兼有上升沿和下降沿   |

| ES011 | ES010 | TI001 引脚有效沿选择 |
|-------|-------|---------------|
| 0     | 0     | 下降沿           |
| 0     | 1     | 上升沿           |
| 1     | 0     | 禁止设置          |
| 1     | 1     | 兼有上升沿和下降沿     |

| PRM011 | PRM010 | 计数时钟选择                 |              |              |               |               |  |  |  |
|--------|--------|------------------------|--------------|--------------|---------------|---------------|--|--|--|
|        |        |                        | fprs = 2 MHz | fprs = 5 MHz | fprs = 10 MHz | fprs = 20 MHz |  |  |  |
| 0      | 0      | fprs                   | 2 MHz        | 5 MHz        | 10 MHz        | 20 MHz        |  |  |  |
| 0      | 1      | fprs/2 <sup>4</sup>    | 125 kHz      | 312.5 kHz    | 625 kHz       | 1.25 MHz      |  |  |  |
| 1      | 0      | fprs/2 <sup>6</sup>    | 31.25 kHz    | 78.125 kHz   | 156.25 kHz    | 312.5 kHz     |  |  |  |
| 1      | 1      | TI001 有效沿 <sup>推</sup> |              |              |               |               |  |  |  |

注: 外部时钟脉冲宽度要求大于内部时钟(fprs)的两个周期宽度。

备注: fprs: 外围硬件时钟频率

# (5) 端口模式寄存器 0 (PM0)

该寄存器按位设置端口0为输入/输出模式。

如果使用 P01/TO00/Tl010 和 P06/TO01/Tl011 引脚用于定时器输出,则需要将 PM01 和 PM06 以及 P01 与 P06 的输出锁存器清零。

如果使用 P00/Tl000、P01/TO00/Tl010、P05/Tl001/SSI11 和 P06/TO01/Tl011 引脚用于定时器输入,则需要将 PM00、PM01、PM05 和 PM06 设置为 1,此时 P00、P01、P05 和 P06 的输出锁存器可以为 0 也可以为 1。 可由 1 位或 8 位存储器操作指令设置 PM0。

复位信号的产生将 PMO 设置为 FFH。

图 7-15 端口模式寄存器 0 (PM0)的格式

地址: FF20H 复位后: FFH R/W

| 符号  | 7 | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|---|------|------|------|------|------|------|------|
| PM0 | 1 | PM06 | PM05 | PM04 | PM03 | PM02 | PM01 | PM00 |

| PM0n | P0n 引脚 I/O 模式选择(n=0~6) |
|------|------------------------|
| 0    | 输出模式(输出缓冲器打开)          |
| 1    | 输入模式(输出缓冲器关闭)          |

# 7.4 16 位定时器/事件计数器 00 和 01 的操作

### 7.4.1 间隔定时器的操作

如果 16 位定时器模式控制寄存器 (TMC0n)的第 3 和 2 位(TMC0n3 和 TMC0n2)为 11 (清零&启动模式(在 TM0n 与 CR00n 匹配时进入)),则启动计数操作与计数时钟同步。

当之后的 TM0n 值与 CR00n 值匹配时,将 TM0n 清零(0000H)并产生一个匹配中断信号(INTTM00n)。INTTM00n 信号允许 TM0n 作为间隔定时器操作。

# 备注: 1. 如需了解 I/O 引脚的设置,可参见 7.3 (5) 端口模式寄存器 0 (PM0).

2. 要了解如何允许 INTTM00n 中断,参见第二十章 中断功能。

图 7-16 间隔定时器操作框图



图 7-17 间隔定时器操作的基本时序示例



# 图 7-18 间隔定时器操作的寄存器设置示例

# (a) 16 位定时器模式控制寄存器 0n (TMC0n)



# (b) 捕捉/比较控制寄存器 0n (CRC0n)

|   |   |   |   |   | CRC0n2 | CRC0n1 | CRC0n0 |          |
|---|---|---|---|---|--------|--------|--------|----------|
| 0 | 0 | 0 | 0 | 0 | 0      | 0      | 0      |          |
|   |   |   |   |   |        |        |        | CR00n 用作 |
|   |   |   |   |   |        |        |        | 比较寄存器    |

# (c) 16 位定时器输出控制寄存器 0n (TOC0n)

|   | OSPT0n | OSPE0n | TOC0n4 | LVS0n | LVR0n | TOC0n1 | TOE0n |
|---|--------|--------|--------|-------|-------|--------|-------|
| 0 | 0      | 0      | 0      | 0     | 0     | 0      | 0     |

# (d) 预分频器模式寄存器 On (PRMOn)

| ES1n1 | ES1n0 | ES0n1 | ES0n0 | 3 | 2 | PRM0n1 | PRM0n0 | _      |
|-------|-------|-------|-------|---|---|--------|--------|--------|
| 0     | 0     | 0     | 0     | 0 | 0 | 0/1    | 0/1    |        |
|       |       |       |       |   |   |        |        | 选择计数时钟 |

# (e) 16 位定时器计数器 0n (TM0n)

通过读取 TM0n, 获得计数值。

# (f) 16 位捕捉/比较寄存器 00n (CR00n)

如果 CR00n=M,则间隔时间表示如下。

● 间隔时间 = (M + 1) × 计数时钟周期

禁止将 CR00n 设置为 0000H。

# (g) 16 位捕捉/比较寄存器 01n (CR01n)

通常 CR01n 不用作间隔定时器。但当 CR01n 的值与 TM0n 的值匹配时,会产生比较匹配中断(INTTM01n)。因此通过使用中断屏蔽标志(TMMK01n)屏蔽中断请求。

图 7-19 间隔定时器软件处理示例



# <1> 计数操作启动流程



在将 TMC0n3 与 TMC0n2 设置为 11 之前, 先对这些寄存器进行初始化设置。

开始计数操作

# <2> 计数操作停止流程



通过将 TMC0n3 与 TMC0n2 清零(00) 对计数器进行初始化并停止计数。

#### 7.4.2 方波输出操作

当 16 位定时器/事件计数器 0n 用作间隔定时器时(参见 **7.4.1**),通过将 16 位定时器输出控制寄存器 0n (TOC0n)设置为 03H,可以从 TO0n 引脚输出一个方波。

当 TMC0n3 与 TMC0n2 被设置为 11 时(计数清零&启动模式(在 TM0n 与 CR00n 匹配时进入)),启动计数操作与计数时钟同步。

当之后 TM0n 的值与 CR00n 的值匹配时,将 TM0n 清零(0000H)、产生中断信号(INTTM00n)并反转 TO0n 引脚的输出。反转的 TO0n 引脚输出以恒定的间隔允许 TO0n 输出一个方波。

备注: 1. 如需了解 I/O 引脚的设置,可参见 7.3 (5) 端口模式寄存器 0 (PM0)。

2. 要了解如何允许 INTTM00n 信号中断, 参见第二十章 中断功能。

图 7-20 方波输出操作框图



备注: n = 0, 1

图 7-21 方波输出操作的基本时序示例



## 图 7-22 方波输出操作的寄存器设置示例

# (a) 16 位定时器模式控制寄存器 0n (TMC0n)



#### (b) 捕捉/比较控制寄存器 0n (CRC0n)



## (c) 16 位定时器输出控制寄存器 0n (TOC0n)



## (d) 预分频器模式寄存器 0n (PRM0n)



#### (e) 16 位定时器计数器 On (TMOn)

通过读取 TM0n, 获得计数值。

# (f) 16 位捕捉/比较寄存器 00n (CR00n)

如果 CR00n=M,则间隔时间表示如下。

● 方波频率 = 1 / [2 × (M + 1) × 计数时钟周期]

禁止将 CR00n 设置为 0000H。

### (g) 16 位捕捉/比较寄存器 01n (CR01n)

通常 CR01n 不用作方波输出。但当 CR01n 的值与 TM0n 的值匹配时,会产生比较匹配中断(INTTM01n)。 因此,通过使用中断屏蔽标志(TMMK01n)屏蔽中断请求。

图 7-23 方波输出软件处理示例



#### <1> 计数操作启动流程



## <2> 计数操作停止流程



注: 设置 TOC0n 时必须特别小心。如需了解详细信息,参见 7.3 (3) 16 位定时器输出控制寄存器 0n (TOC0n)。

#### 7.4.3 外部事件计数器的操作

当预分频器模式寄存器 On (PRMOn)的第 1 和 0 位(PRMOn1 和 PRMOn0)被设置为 11(使用 TIOOn 引脚的有效沿计数) 以及 16 位定时器模式控制寄存器 On (TMCOn)的第 3 和 2 位(TMCOn3 和 TMCOn2)被设置为 11 时,开始对外部事件输入的有效沿进行计数,并产生用于指示 TMOn 和 CROOn 之间匹配的匹配中断信号(INTTMOOn)。

如果要输入外部事件,可以使用 TIOOn 引脚。因此定时器/事件计数器不能用作清零&启动模式(通过 TIOOn 引脚有效 沿(TMCOn3 与 TMCOn2 = 10)进入)下的外部事件计数器。

INTTM00n 信号按下列时序产生。

• INTTM00n 信号产生时序 (第 2 次或之后产生) = 外部事件输入的有效沿检测次数 × (CR00n 的设置值 + 1)

但在定时器/事件计数器开始操作后,将按以下时序立即产生第1次匹配中断。

• INTTM00n 信号产生时序 (仅在第 1 次产生) =外部事件输入的有效沿检测次数× (CR00n 的设置值 + 2)

如果要检测有效沿,则应在 fprs 时钟周期内对输入到 TIOOn 引脚的信号进行采样。在一个周期内检测到两次脉冲沿时才认为检测到有效沿,这样可以消除一个窄脉冲宽度的噪音。

- 备注: 1. 如需了解 I/O 引脚的设置,参见 7.3 (5) 端口模式寄存器 0 (PM0).
  - 2. 要了解如何允许 INTTM00n 信号中断,参见第二十章 中断功能。

图 7-24 外部事件计数器操作框图



## 图 7-25 外部事件计数器模式下寄存器设置示例

# (a) 16 位定时器模式控制寄存器 0n (TMC0n)



# (b) 捕捉/比较控制寄存器 0n (CRC0n)



## (c) 16 位定时器输出控制寄存器 0n (TOC0n)

|   | OSPT0n | OSPE0n | TOC0n4 | LVS0n | LVR0n | TOC0n1 | TOE0n |
|---|--------|--------|--------|-------|-------|--------|-------|
| 0 | 0      | 0      | 0      | 0     | 0     | 0      | 0     |

## (d) 预分频器模式寄存器 On (PRMOn)



### (e) 16 位定时器计数器 0n (TM0n)

通过读取 TM0n, 获得计数值。

## (f) 16 位捕捉/比较寄存器 00n (CR00n)

如果 M=CR00n,则当外部事件数=(M + 1)时产生中断信号(INTTM00n)。 禁止将 CR00n 设置为 0000H。

## (g) 16 位捕捉/比较寄存器 01n (CR01n)

通常 CR01n 不用于外部事件计数器模式。但当 CR01n 的值与 TM0n 的值匹配时会产生比较匹配中断 (INTTM01n)。

因此,通过使用中断屏蔽标志(TMMK01n)屏蔽中断请求。

## 图 7-26 外部事件计数器模式下的软件处理示例



## <1> 计数操作启动流程



## <2> 计数操作停止流程



### 7.4.4 清零&启动模式(通过 TI00n 引脚有效沿输入进入)下的操作

当 16 位定时器模式控制寄存器 0n (TMC0n)的第 3 和 2 位(TMC0n3 和 TMC0n2)被设置为 10(清零&启动模式(通过 TI00n 引脚有效沿输入进入))并且向定时器/事件计数器提供计数时钟(由 PRM0n 设置)时,TM0n 开始计数。在计数操作期间,如果检测到 TI00n 引脚的有效沿,则将 TM0n 清零(0000H)并再次开始计数。如果没有检测到 TI00n 引脚的有效沿,则 TM0n 溢出并继续计数。

可通过 TI00n 引脚的有效沿对 TM0n 清零。在操作开始后,不会立即启动计数器。

CR00n与 CR01n可用作比较寄存器和捕捉寄存器。

#### (a) CR00n 与 CR01n 用作比较寄存器

当 TMOn 的值与 CR00n、CR01n 的值匹配时,产生信号 INTTM00n 与 INTTM01n。

#### (b) CR00n 与 CR01n 用作捕捉寄存器

当有效沿输入到 TI01n 引脚时(或者当反向的有效脉冲沿输入到 TI00n 引脚时), TM0n 的计数值被捕捉到 CR00n,同时产生 INTTM00n 信号。

当有效沿输入到 TI00n 引脚时,TM0n 的计数值被捕捉到 CR01n,同时产生 INTTM01n 信号。一旦捕捉了计数值,计数器即被清零(0000H)。

注意事项: 不要将 TI00n 引脚的有效沿(PRM0n1 与 PRM0n0 = 11)设置为计数时钟。当 PRM0n1 与 PRM0n0 = 11 时,将 TM0n 清零。

备注: 1. 如需了解 I/O 引脚的设置,参见 7.3 (5) 端口模式寄存器 0 (PM0).

2. 要了解如何允许 INTTM00n 信号中断,参见第二十章 中断功能。

#### (1) 清零&启动模式(通过 TI00n 引脚有效沿输入进入)下的操作

(CR00n: 比较寄存器, CR01n: 比较寄存器)

图 7-27 清零&启动模式(通过 TI00n 引脚有效沿输入进入)的框图 (CR00n: 比较寄存器, CR01n: 比较寄存器)



# 图 7-28 清零&启动模式(通过 Tl00n 引脚有效沿输入进入)时序示例 (CR00n: 比较寄存器, CR01n: 比较寄存器)

### (a) TOC0n = 13H, PRM0n = 10H, CRC0n, = 00H, TMC0n = 08H



## (b) TOC0n = 13H, PRM0n = 10H, CRC0n, = 00H, TMC0n = 0AH



(a)与(b) 根据 16 位定时器模式控制寄存器 0n (TMC0n) 第 1 位(TMC0n1) 的设置不同有如下变化。

- (a) 当 TMOn 与比较寄存器匹配时反转 TOOn 引脚的输出电平。
- (b) 当 TMOn 与比较寄存器匹配或者检测到 TIOOn 有效沿时反转 TOOn 引脚的输出电平。

# (2) 清零&启动模式(通过 Tl00n 引脚有效沿输入进入)下的操作 (CR00n: 比较寄存器, CR01n: 捕捉寄存器)

图 7-29 清零&启动模式(通过 TI00n 引脚有效沿输入进入)的框图 (CR00n: 比较寄存器, CR01n: 捕捉寄存器)



备注: n = 0, 1

图 7-30 清零&启动模式(通过 TI00n 引脚有效沿输入进入) 时序示例 (CR00n: 比较寄存器, CR01n: 捕捉寄存器) (1/2)

(a) TOC0n = 13H, PRM0n = 10H, CRC0n, = 04H, TMC0n = 08H, CR00n = 0001H



这是一个应用示例: 当捕捉到计数值并清零时反转 TOOn 引脚的输出电平。

当检测到 TIOOn 引脚的有效沿时捕捉计数值存入 CR01n 并将 TM0n 清零(0000H)。当 TM0n 的计数值=0001H 时,产生比较匹配中断信号(INTTM00n),并反转 TO0n 引脚的输出电平。

# 图 7-30 清零&启动模式(通过 TI00n 引脚有效沿输入进入)时序示例 (CR00n: 比较寄存器, CR01n: 捕捉寄存器) (2/2)





这是一个应用示例: 当捕捉计数值并清零时从 TOOn 引脚输出 CR00n 设置的宽度(本例是 4 个时钟)。 当检测到 TI00n 引脚的有效沿时,捕捉计数值存入 CR01n、产生捕捉中断信号(INTTM01n)、将 TM0n 清零(0000H) 并反转 TOOn 引脚的输出电平。当 TM0n 的计数值=0003H 时(已经计数 4 个时钟),产生比较匹配中断信号 (INTTM00n)并反转 TOOn 引脚的输出电平。

# (3) 清零&启动模式(通过 TI00n 引脚有效沿输入进入)的操作 (CR00n: 捕捉寄存器, CR01n: 比较寄存器)

图 7-31 清零&启动模式(通过 TI00n 引脚有效沿输入进入)的框图 (CR00n: 捕捉寄存器, CR01n: 比较寄存器)



# 图 7-32 清零&启动模式(通过 TI00n 引脚有效沿输入进入) 时序示例 (CR00n: 捕捉寄存器, CR01n: 比较寄存器) (1/2)

## (a) TOC0n = 13H, PRM0n = 10H, CRC0n, = 03H, TMC0n = 08H, CR01n = 0001H



这是一个应用示例: 当捕捉计数值并清零时反转 TO0n 引脚的输出电平。

在检测到 TI00n 引脚的上升沿时将 TM0n 清零,而在检测到 TI00n 引脚的下降沿时,TM0n 的计数值被捕捉到 CR00n。

当捕捉/比较控制寄存器 0n (CRC0n)的第 1 位(CRC0n1)=1 时,TM0n 的计数值被捕捉到 CR00n(在 Tl00n 引脚输入信号的反向沿捕捉),但不产生捕捉中断信号(INTTM00n)。然而当检测到 Tl01n 引脚的有效沿时产生 INTTM00n 信号。如果不使用 INTTM00n 信号,则将其屏蔽。

# 图 7-32 清零&启动模式(通过 TI00n 引脚有效沿输入进入) 时序示例 (CR00n: 捕捉寄存器, CR01n: 比较寄存器) (2/2)





这是一个应用示例: 当捕捉计数值并清零时从 TO0n 引脚输出 CR01n 设置的宽度(本例是 4 个时钟)。

在检测到 TI00n 引脚的上升沿时将 TM0n 清零(0000H),而在检测到 TI00n 引脚的下降沿时,TM0n 的计数值被捕捉到 CR00n。

当捕捉/比较控制寄存器 On (CRCOn)的第 1 位=1 时,TMOn 的计数值被捕捉到 CROOn(在 TIOOn 引脚输入信号的反向沿捕捉),但不产生捕捉中断信号(INTTMOOn)。然而当检测到 TIO1n 引脚的有效沿时产生 INTTMOOn 信号。如果不使用 INTTMOOn 信号,则将其屏蔽。

# (4) 清零&启动模式(通过 Tl00n 引脚有效沿输入进入)下的操作 (CR00n: 捕捉寄存器, CR01n: 捕捉寄存器)

图 7-33 清零&启动模式(通过 TI00n 引脚有效沿输入进入)的框图 (CR00n: 捕捉寄存器, CR01n: 捕捉寄存器)



注: 当使用检测 TI01n 引脚的有效沿时不能使用定时器输出(TO0n)。

备注: n = 0, 1

图 7-34 清零&启动模式(通过 TI00n 引脚有效沿输入进入)时序示例 (CR00n: 捕捉寄存器, CR01n: 捕捉寄存器) (1/3)

(a) TOC0n = 13H, PRM0n = 30H, CRC0n = 05H, TMC0n = 0AH



这是一个应用示例: 当检测到 TI00n 引脚的上升沿或下降沿时捕捉计数值存入 CR01n、将 TM0n 清零并反转 TO0n 引脚的输出

在检测到 TIO1n 引脚的脉冲沿时产生中断信号(INTTM00n)。如果不使用 INTTM00n 信号,则将其屏蔽。

图 7-34 清零&启动模式(通过 TI00n 引脚有效沿输入进入)时序示例 (CR00n: 捕捉寄存器, CR01n: 捕捉寄存器) (2/3)





这是一个时序示例: 当脉冲沿不输入到 TI00n 引脚时, 检测到 TI01n 引脚的上升沿或下降沿时捕捉计数值存入 CR00n。

# 图 7-34 清零&启动模式(通过 TI00n 引脚有效沿输入进入)时序示例 (CR00n: 捕捉寄存器, CR01n: 捕捉寄存器) (3/3)





这是一个应用示例:对输入到 TIOOn 引脚的信号脉冲宽度进行测量。

通过设置 CRC0n,在 TI00n 引脚下降沿(也可以是上升沿)的反向沿捕捉计数值存入 CR00n,而在 TI00n 引脚下降沿存入 CR01n。

可以通过下列表达式计算输入脉冲的高电平和低电平宽度。

- 高电平宽度 = [CR01n 的值] [CR00n 的值] × [计数时钟周期]
- 低电平宽度 = [CR00n 的值] × [计数时钟周期]

如果选择 TI00n 引脚脉冲的反向沿作为触发,捕捉计数值并存入 CR00n,则不会产生 INTTM00n 信号。在产生 INTTM01n 信号后立即读取 CR00n 和 CR01n,测量脉冲宽度。

但如果将预分频器模式寄存器 0n (PRM0n)的第 6 和 5 位(ES1n1 and ES1n0)指示的有效沿输入 TI01n 引脚,则不会捕捉计数值,但会产生 INTTM00n 信号。如果要测量 TI00n 引脚的脉冲宽度,在不使用 INTTM00n 信号时将其屏蔽。

## 图 7-35 在清零&启动模式(通过 TI00n 引脚有效沿输入进入)下寄存器设置示例(1/2)

# (a) 16 位定时器模式控制寄存器 0n (TMC0n)



### (b) 捕捉/比较控制寄存器 0n (CRC0n)



# (c) 16 位定时器输出控制寄存器 0n (TOC0n)



注: 当使用检测 TI01n 引脚有效沿时不能使用定时器输出(TO0n)。

# 图 7-35 在清零&启动模式(通过 TI00n 引脚有效沿输入进入)下寄存器设置示例(2/2)

# (d) 预分频器模式寄存器 On (PRMOn)



## (e) 16 位定时器计数器 0n (TM0n)

通过读取 TM0n, 获得计数值。

#### (f) 16 位捕捉/比较寄存器 00n (CR00n)

当该寄存器用作比较寄存器并且当其值与 TMOn 的值匹配时,产生中断信号(INTTMOOn)。但不对 TMOn 清零。

如果要将该寄存器用作捕捉寄存器,则应选择 TI00n 或 TI01n 引脚<sup>性</sup>输入作为捕捉触发。当检测到捕捉触发的有效沿时,将 TM0n 的计数值存入 CR00n。

注: 当使用检测 TI01n 引脚的有效沿时不能使用定时器输出(TO0n)。

## (g) 16 位捕捉/比较寄存器 01n (CR01n)

当该寄存器用作捕捉寄存器,则 TI00n 引脚输入作为捕捉触发。当检测到捕捉触发的有效沿时,将 TM0n 的计数值存入 CR01n。





#### <1> 计数操作启动流程

# <3> 计数操作停止流程



<2> TM0n 寄存器清零&启动流程



注: 设置 TOC0n 时必须特别小心。如需了解详细信息,可参见 7.3 (3) 16 位定时器输出控制寄存器 0n (TOC0n)。

#### 7.4.5 自由运行定时器操作

当 16 位定时器模式控制寄存器 0n(TMC0n)的第 3 和 2 位(TMC0n3 与 TMC0n2)为 01(自由运行定时器模式)时,16 位定时器/事件计数器 0n 连续计数并与计数时钟同步。当计数值上升到 FFFFH 时,在下一个时钟将溢出标志(OVF0n)设置为 1、将 TM0n 清零(0000H)并继续计数。通过软件执行 CLR 指令将 OVF0n 清零(0)。

可以使用以下三种自由运行定时器操作。

- CR00n 和 CR01n 都用作比较寄存器。
- CR00n与 CR01n一个用作比较寄存器,另一个用作捕捉寄存器。
- CR00n 和 CR01n 都用作捕捉寄存器。

**备注:** 1. 如需了解 I/O 引脚的设置,参见 7.3 (5) 端口模式寄存器 0 (PM0)。

2. 要了解如何允许 INTTM00n 信号中断,可参见第二十章 中断功能。

# (1) 自由运行定时器模式操作

(CR00n: 比较寄存器, CR01n: 比较寄存器)

图 7-37 自由运行定时器模式的框图 (CR00n: 比较寄存器, CR01n: 比较寄存器)



# 图 7-38 自由运行定时器模式时序示例 (CR00n: 比较寄存器, CR01n: 比较寄存器,

#### • TOC0n = 13H, PRM0n = 00H, CRC0n = 00H, TMC0n = 04H



这是一个应用示例:两个比较寄存器在自由运行定时器模式下使用。

每当 TM0n 的计数值与 CR00n 或 CR01n 的值匹配时,反转 TO0n 引脚的输出电平。当计数值与寄存器值匹配时,产生 INTTM00n 或 INTTM01n 信号。

备注: n = 0, 1

#### (2) 自由运行定时器模式操作

(CR00n: 比较寄存器, CR01n: 捕捉寄存器)

图 7-39 自由运行定时器模式的框图 (CR00n: 比较寄存器, CR01n: 捕捉寄存器)



# 图 7-40 自由运行定时器模式时序示例 (CR00n: 比较寄存器, CR01n: 捕捉寄存器)

#### • TOC0n = 13H, PRM0n = 10H, CRC0n = 04H, TMC0n = 04H



这是一个应用示例:在自由运行定时器模式下同时使用一个比较寄存器和一个捕捉寄存器。在本例中每当 TMOn 的计数值与 CR00n 的值匹配时反转 TOOn 引脚的输出电平。此外每当检测到 Tl00n 引脚的有效沿时,产生 INTTM01n 信号,并捕捉 TMOn 的计数值存入 CR01n。

## (3) 自由运行定时器模式操作

(CR00n: 捕捉寄存器, CR01n: 捕捉寄存器)

图 7-41 自由运行定时器模式的框图 (CR00n: 捕捉寄存器, CR01n: 捕捉寄存器)



**备注:** 1. 如果在自由运行定时器模式下,CR00n 与 CR01n 用作捕捉寄存器,则不反转 TO0n 引脚的输出电平。

但如果 16 位定时器模式控制寄存器 0n (TMC0n)的第 1 位(TMC0n1)=1,则每次检测到 Tl00n 引脚的有效沿时可以反转。

**2.** n = 0, 1

# 图 7-42 自由运行定时器模式时序示例 (CR00n: 捕捉寄存器, CR01n: 捕捉寄存器) (1/2)

## (a) TOC0n = 13H, PRM0n = 50H, CRC0n = 05H, TMC0n = 04H



这是一个应用示例:自由运行定时器模式下,在各自触发信号的有效沿捕捉的计数值存入各自的捕捉寄存器中。 当检测到 Tl00n 引脚输入的有效沿时捕捉计数值并存入 CR01n,而当检测到 Tl01n 引脚输入的有效沿时捕捉计数 值并存入 CR00n。

# 图 7-42 自由运行定时器模式时序示例 (CR00n: 捕捉寄存器, CR01n: 捕捉寄存器) (2/2)

#### (b) TOC0n = 13H, PRM0n = C0H, CRC0n = 05H, TMC0n = 04H



这是一个应用示例:自由运行定时器模式下,检测 TI01n 引脚的两种脉冲沿,计数值被捕捉到 CR00n。 当 CR00n 与 CR01n 都用作捕捉寄存器并且仅检测到 TI01n 引脚的有效沿时,计数值不能被捕捉到 CR01n。

## 图 7-43 自由运行定时器模式下寄存器设置示例 (1/2)

# (a) 16 位定时器模式控制寄存器 0n (TMC0n)



#### (b) 捕捉/比较控制寄存器 0n (CRC0n)



# (c) 16 位定时器输出控制寄存器 0n (TOC0n)



## 图 7-43 自由运行定时器模式下寄存器设置示例 (2/2)

# (d) 预分频器模式寄存器 0n (PRM0n)



### (e) 16 位定时器计数器 0n (TM0n)

通过读取 TM0n, 获得计数值。

#### (f) 16 位捕捉/比较寄存器 00n (CR00n)

当该寄存器用作比较寄存器并且当其值与 TMOn 的计数值匹配时,产生中断信号(INTTMOOn)。但不对 TMOn 计数值清零。

若要用作捕捉寄存器,则应选择 TI00n 或 TI01n 引脚输入作为捕捉触发。当检测到捕捉触发的有效沿时,将 TM0n 的计数值存入 CR00n。

# (g) 16 位捕捉/比较寄存器 01n (CR01n)

当该寄存器用作比较寄存器并且当其值与 TMOn 的计数值匹配时,产生中断信号(INTTMO1n)。但不对 TMOn 计数值清零。

当该寄存器用作捕捉寄存器时,将 TI00n 引脚输入作为捕捉触发。当检测到捕捉触发的有效沿时,将 TM0n 的 计数值存入 CR01n。

图 7-44 自由运行定时器模式下软件处理示例



#### <1> 计数操作启动流程



# <2>计数操作停止流程



注: 要特别注意 TOC0n 的设置。如需了解详细信息,可参见 7.3 (3) 16 位定时器输出控制寄存器 0n (TOC0n).

#### 7.4.6 PPG 输出操作

当 16 位定时器模式控制寄存器 0n (TMC0n) 的第 3 和 2 位(TMC0n3 与 TMC0n2)=11 时(在 TM0n 与 CR00n 匹配时 清零&启动),在由 CR00n 设置的周期内从 TO0n 引脚输出方波(具有通过 CR01n 预先设置的一个脉冲宽度)作为 PPG(Programmable Pulse Generator 可编程脉冲发生器)信号。

以下是作为 PPG 输出的脉冲的周期与占空比。

- 脉冲周期 = (CR00n 的设置值 + 1) × 计数时钟周期
- 占空比 = (CR01n 的设置值 + 1) / (CR00n 的设置值 + 1)

注意事项: 若在操作期间修改占空比(CR01n 寄存器的值),可参阅 7.5.1 TM0n 操作期间 CR01n 的重写。

**备注:** 1. 如需了解 I/O 引脚的设置,可参见 7.3 (5) 端口模式寄存器 0 (PM0)。

2. 要了解如何允许 INTTM00n 信号中断, 参见第二十章 中断功能。

图 7-45 PPG 输出操作的框图



## 图 7-46 PPG 输出操作的寄存器设置示例

## (a) 16 位定时器模式控制寄存器 0n (TMC0n)



#### (b) 捕捉/比较控制寄存器 0n (CRC0n)



## (c) 16 位定时器输出控制寄存器 0n (TOC0n)



## (d) 预分频器模式寄存器 On (PRMOn)



#### (e) 16 位定时器计数器 0n (TM0n)

通过读取 TM0n, 获得计数值。

#### (f) 16 位捕捉/比较寄存器 00n (CR00n)

当该寄存器的值与 TMOn 的计数值匹配时,产生中断信号(INTTMOOn)。但不对 TMOn 的计数值清零。

#### (g) 16 位捕捉/比较寄存器 01n (CR01n)

当该寄存器的值与 TMOn 的计数值匹配时,产生中断信号(INTTMO1n)。但不对 TMOn 的计数值清零。

注意事项: 对 CR00n 与 CR01n 进行设置,以满足条件 0000H < CR01n < CR00n ≤ FFFFH。

# 图 7-47 PPG 输出操作软件处理示例



<1> 计数操作启动流程

<2> 计数操作停止流程



- 注: 必须特别注意 TOC0n 的设置。如需了解详细信息,可参见 7.3 (3) 16 位定时器输出控制寄存器 0n (TOC0n)。
- **备注:** 1. PPG 脉冲周期 = (M + 1) × 计数时钟周期 PPG 占空比 = (N + 1)/(M + 1)
  2. n = 0, 1

#### 7.4.7 单脉冲输出操作

通过将 16 位定时器模式控制寄存器 0n (TMC0n) 的第 3 和 2 位(TMC0n3 与 TMC0n2)设置为 01 (自由运行定时器模式)或 10(清零&启动模式 (通过 TI00n 引脚有效沿进入)),以及将 16 位定时器输出控制寄存器 0n (TOC0n)的第 5 位 (OSPE0n)设置为 1,可以输出一个单脉冲。

当 TOC0n 的第 6 位(OSPT0n)=1 时或者在定时器操作期间将有效沿输入到 TI00n 引脚时,触发 TM0n 的清零&启动,并且从 TO0n 引脚只输出一次反映 CR00n 与 CR01n 之间差距的脉冲。

- 注意事项: 1. 当单脉冲输出时,不要再次输入触发(设置 OSPT0n=1 或者检测 TI00n 引脚的有效沿)。在当前单脉冲输出完成后产生触发,才可再次输出单脉冲。
  - 2. 如果要使用单脉冲输出触发(仅设置 OSPT0n=1),则不要修改 TI00n 引脚或其复用功能端口引脚的电平。否则可能会产生异常输出的脉冲。
- 备注: 1. 如需了解 I/O 引脚的设置,可参见 7.3 (5) 端口模式寄存器 0 (PM0).
  - 2. 要了解如何允许 INTTM00n 信号中断,可参见第二十章 中断功能。

TI00n 脉冲沿检测 清零 OSPT0n 位 OSPE0n 位 定时器计数器 计数时钟。 (TM0n) 匹配信号 中断信号 可操作位 (INTTM00n) (TMC0n3, TMC0n2) 比较寄存器 输出 -◎ TO0n 引脚 (CR00n) 控制器 匹配信号 (INTTM01n) 比较寄存器 (CR01n)

图 7-48 单脉冲输出操作的框图

# 图 7-49 单脉冲输出操作的寄存器设置示例 (1/2)

# (a) 16 位定时器模式控制寄存器 0n (TMC0n)



## (b) 捕捉/比较控制寄存器 0n (CRC0n)



# (c) 16 位定时器输出控制寄存器 0n (TOC0n)



# (d) 预分频器模式寄存器 On (PRMOn)



## 图 7-49 单脉冲输出操作的寄存器设置示例 (2/2)

# (e) 16 位定时器计数器 0n (TM0n)

通过读取 TMOn,可获得计数值。

# (f) 16 位捕捉/比较寄存器 00n (CR00n)

当输出单脉冲时该寄存器用作比较寄存器。当 TM0n 的值与 CR00n 的值匹配时,产生中断信号(INTTM00n)并 反转 TO0n 引脚的输出电平。

## (g) 16 位捕捉/比较寄存器 01n (CR01n)

当输出单脉冲时,该寄存器用作比较寄存器。当 TM0n 的值与 CR01n 的值匹配时,产生中断信号(INTTM01n) 并反转 TO0n 引脚的输出电平。

注意事项: 不要为 CR0n0 与 CR0n1 设置相同的值或设置为 0000H。





- 从输入单脉冲触发信号到输出单脉冲的时间
  - = (M + 1) × 计数时钟周期
- 单脉冲输出活动电平宽度
  - = (N M) × 计数时钟周期

## 图 7-50 单脉冲输出操作软件处理示例 (2/2)

#### <1> 计数操作启动流程



# <2>单脉冲触发输入流程



### <3> 计数操作停止流程



注: 必须特别注意 TOC0n 的设置。如需了解详细信息,可参见 7.3 (3) 16 位定时器输出控制寄存器 0n (TOC0n)。

### 7.4.8 脉冲宽度测量操作

TMOn 可用于测量输入到 TIOOn 与 TIO1n 引脚的信号的脉冲宽度。

嘂

选择

捕捉信号

可以通过在自由运行定时器模式下操作 16 位定时器/事件计数器 0n 以及通过同步使用 Tl00n 引脚输入信号的脉冲沿 重新启动定时器,来进行测量。

当产生中断时,读取捕捉寄存器的有效值,并测量脉冲宽度。检测 16 位定时器模式控制寄存器 0n (TMC0n)的第 0 位(OVF0n)。如果该位被设置为 1,则由软件将其清零。

可操作位 (TMC0n3, TMC0n2) 定时器计数器 计数时钟 (TM0n) 捕捉寄存器 中断信号 (INTTM01n) (CR01n) 捕捉信号 脉冲沿 检测 TI00n引脚〇

捕捉寄存器

(CR00n)

图 7-51 脉冲宽度测量 (自由运行定时器模式)的框图

备注: n = 0, 1

TI01n引脚〇

脉冲沿 检测

图 7-52 脉冲宽度测量的框图 (清零&启动模式(通过 TI00n 引脚有效沿输入进入))



备注: n = 0, 1

中断信号 (INTTM00n)

可以使用以下三种方法测量脉冲宽度。

- 通过使用 TI00n 与 TI01n 引脚的两个输入信号测量脉冲宽度(自由运行定时器模式)
- 通过使用 TI00n 引脚的一个输入信号测量脉冲宽度(自由运行定时器模式)
- 通过使用 TI00n 引脚的一个输入信号测量脉冲宽度(清零&启动模式(通过 TI00n 引脚有效沿输入进入))

### **备注:** 1. 如需了解 I/O 引脚的设置,可参见 7.3 (5) 端口模式寄存器 0 (PM0).

2. 要了解如何允许 INTTM00n 信号中断,可参见第二十章 中断功能。

### (1) 通过使用 TI00n 与 TI01n 引脚的两个输入信号测量脉冲宽度 (自由运行定时器模式)

设置自由运行定时器模式(TMC0n3 与 TMC0n2 = 01)。当检测到 TI00n 引脚的有效沿时,TM0n 的计数值被捕捉到 CR01n。当检测到 TI01n 引脚的有效沿时,TM0n 的计数值被捕捉到 CR00n。规定检测 TI00n 与 TI01n 引脚的两种脉冲沿。

使用这种测量方法,要从每个输入信号的脉冲沿捕捉的计数值中减去预设值。因此要将先前捕捉的值事先存入一个单独的寄存器中。

如果产生溢出,则在当前捕捉值减去先前捕捉的值后计数值为负,并因此产生借位(将程序状态字(PSW)的第 0 位 (CY)置 1)。如果发生这种情况,可以忽略 CY 并将计算结果作为脉冲宽度。此外,将 16 位定时器模式控制寄存器 On (TMC0n)的第 0 位(OVF0n)清零(0)。

#### 图 7-53 脉冲宽度测量时序示例 (1)

#### FFFFH TM0n 寄存器 В D 0000H 可操作位 00 01 (TMC0n3, TMC0n2) 捕捉触发输入 (TI00n) 捕捉寄存器 0000H Μ Ν S Ρ Q (CR01n) 捕捉中断 (INTTM01n) 捕捉触发输入 (TI01n) 捕捉寄存器 0000H Α В С D Ε (CR00n)

• TMC0n = 04H, PRM0n = F0H, CRC0n = 05H

备注: n = 0, 1

捕捉中断 (INTTM00n) 溢出标志 (OVF0n)

清零(写入0)

清零(写入 0)

清零(写入 0)

清零(写入0)

### (2) 通过使用 TI00n 引脚的一个输入信号测量脉冲宽度(自由运行模式)

设置自由运行定时器模式(TMC0n3 与 TMC0n2 = 01)。在 TI00n 引脚检测到反向的有效沿时,将 TM0n 的计数值捕捉到 CR00n。当检测到 TI00n 引脚的有效沿时,将 TM0n 的计数值捕捉到 CR01n。

使用这种测量方法,在测量从一个脉冲沿到另一个脉冲沿的宽度时将数值存入分开的两个捕捉寄存器中。因此,不必保存捕捉值。将两个捕捉寄存器的值相减,可以计算高电平宽度、低电平宽度和周期。

如果产生溢出,则当两个捕捉的计数值相减后结果为负,并因此产生借位(将程序状态字(PSW)的第 0 位(CY)置 1)。如果发生这种情况,可以忽略 CY 并将计算结果作为脉冲宽度。此外,将 16 位定时器模式控制寄存器 0n (TMC0n)的第 0 位(OVF0n)清零(0)。

图 7-54 脉冲宽度测量时序示例 (2)

### • TMC0n = 04H, PRM0n = 10H, CRC0n = 07H



备注: n = 0.1

### (3) 通过使用 TI00n 引脚的一个输入信号测量脉冲宽度(清零&启动模式(通过 TI00n 引脚有效沿输入进入))

设置清零&启动模式(通过 TI00n 引脚有效沿进入)(TMC0n3 与 TMC0n2 = 10)。在 TI00n 引脚检测到反向的有效沿时,将 TM0n 的计数值捕捉到 CR00n。当检测到 TI00n 引脚的有效沿时,将 TM0n 的计数值捕捉到 CR01n,并将 TM0n 清零(0000H)。因此,如果 TM0n 没有溢出,则在 CR01n 中存入一个周期。

如果产生溢出,则将 10000H 加上 CR01n 的值,结果作为一个周期。此外,将 16 位定时器模式控制寄存器 0n (TMC0n)的第 0 位(OVF0n)清零(0)。

图 7-55 脉冲宽度测量时序示例 (3)

• TMC0n = 08H, PRM0n = 10H, CRC0n = 07H



<1> 脉冲周期 =

(10000H × OVF0n 位被设置为 1 的次数 +CR01n 的捕捉值) × 计数时钟周期

<2> 高电平脉冲宽度 =

(10000H × OVF0n 位被设置为 1 的次数+ CR00n 的捕捉值) ×计数时钟周期

<3> 低电平脉冲宽度 =

(脉冲周期 - 高电平脉冲宽度)

### 图 7-56 脉冲宽度测量的寄存器设置示例 (1/2)

## (a) 16 位定时器模式控制寄存器 0n (TMC0n)



### (b) 捕捉/比较控制寄存器 0n (CRC0n)



### (c) 16 位定时器输出控制寄存器 0n (TOC0n)

|   | OSPT0n | OSPE0n | TOC0n4 | LVS0n | LVR0n | TOC0n1 | TOE0n |
|---|--------|--------|--------|-------|-------|--------|-------|
| 0 | 0      | 0      | 0      | 0     | 0     | 0      | 0     |

## (d) 预分频器模式寄存器 On (PRMOn)



备注: n = 0, 1

### 图 7-56 脉冲宽度测量的寄存器设置示例 (2/2)

## (e) 16 位定时器计数器 0n (TM0n)

通过读取 TMOn,可获得计数值。

## (f) 16 位捕捉/比较寄存器 00n (CR00n)

该寄存器用作捕捉寄存器。选择 TI00n 或 TI01n 引脚作为捕捉触发。当检测到指定脉冲沿的捕捉触发时,将 TM0n 的计数值存入 CR00n。

## (g) 16 位捕捉/比较寄存器 01n (CR01n)

该寄存器用作捕捉寄存器。将 TI00n 引脚的输入信号用作捕捉触发。当检测到捕捉触发时,将 TM0n 的计数值 存入 CR01n。

### 图 7-57 脉冲宽度测量软件处理示例 (1/2)

## (a) 自由运行定时器模式示例



### (b) 清零&启动模式(通过 TI00n 引脚有效沿进入)示例



备注: n = 0, 1

### 图 7-57 脉冲宽度测量软件处理示例 (2/2)

### <1> 计数操作启动流程



## <2> 单脉冲触发输入流程



## <3> 计数操作停止流程



注: 当选择 TI00n 引脚输入的反向脉冲沿作为 CR00n 的有效沿时,不产生捕捉中断信号(INTTM00n)。

## 7.5 TM0n 的特殊用途

#### 7.5.1 TM0n 操作期间重写 CR01n

原则上,在 TM0n 操作时(TMC0n3 与 TMC0n2 不等于 00)禁止重写 78K0/KF2 的 CR00n 与 CR01n(当它们用作比较 寄存器时)的值。

但如果 CR01n 用于 PPG 输出且占空比已被修改(在 CR01n 的值与 TM0n 的值匹配后修改 CR01n 的值。如果 CR01n 的值与 TM0n 的值匹配前立即修改 CR01n,则可以会产生异常操作),可以按下列过程修改 CR01n,即使 TM0n 正在操作。

### 修改 CR01n 值的过程

- <1> 禁止中断 INTTM01n (TMMK01n = 1).
- <2> 当 TM0n 的值与 CR01n 的值匹配时(TOC0n4 = 0)禁止反转定时器输出。
- <3> 修改 CR01n 的值
- <4> 等待一个 TM0n 计数时钟周期
- <5> 允许 TMOn 和 CR01n(TOC0n4 = 1) 匹配时进行定时器输出反转操作。
- <6> 将 INTTM01n 的中断标志清零 (TMIF01n = 0)。
- <7> 允许中断 INTTM01n (TMMK01n = 0).

备注: 如需了解 TMIF01n 和 TMMK01n,可参见第二十章 中断功能。

#### 7.5.2 LVS0n 和 LVR0n 的设置

#### (1) LVS0n 和 LVR0n 的使用

LVS0n 与 LVR0n 用于设置 TO0n 引脚输出的默认值并可以在不需要定时器操作时(TMC0n3 与 TMC0n2 = 00)对定时器输出进行反转。当不需要软件控制时将 LVS0n 与 LVR0n 清零(00) (默认值: 低电平输出)。

| LVS0n | LVR0n | 定时器输出状态     |
|-------|-------|-------------|
| 0     | 0     | 无变化 (低电平输出) |
| 0     | 1     | 清零 (低电平输出)  |
| 1     | 0     | 设置 (高电平输出)  |
| 1     | 1     | 禁止设置        |

#### (2) LVS0n 和 LVR0n 的设置

可按以下步骤设置 LVS0n 和 LVR0n。

图 7-58 LVS0n 和 LVR0n 设置流程示例



注意事项: 必须按上述<1>、<2>和<3>步骤设置 LVS0n 和 LVR0n。 步骤<2>可以在<1>之后<3>之前执行。

图 7-59 LVR0n 和 LVS0n 时序示例



- <1> 当 LVS0n 与 LVR0n = 10 时将 TO0n 引脚输出变为高电平。
- <2> 当 LVS0n 与 LVR0n = 01 时将 TO0n 引脚输出变为低电平(如果 LVS0n 与 LVR0n 被清零(00)则引脚输出恒为 高电平)。
- <3> 当 TMC0n3 与 TMC0n2=01、10 或 11 时定时器开始操作。由于在开始操作前 LVS0n 与 LVR0n 被设置为 10, 所以 TO0n 引脚输出从高电平开始。定时器开始操作后,禁止对 LVS0n 与 LVR0n 进行设置,直至 TMC0n3 与 TMC0n2 = 00 (禁止定时器操作)。
- <4> 每当产生中断信号(INTTM00n)时,反转 TO0n 引脚的输出电平。

## 7.6 16 位定时器/事件计数器 00 和 01 注意事项

## (1) 16 位定时器/事件计数器 0n 每个通道的限制条件

表 7-5 显示了每个通道的限制条件。

表 7-5 16 位定时器/事件计数器 0n 每个通道的限制条件

| 操作                              | 限制条件                                           |
|---------------------------------|------------------------------------------------|
| 用作间隔定时器                         | _                                              |
| 用作方波输出                          |                                                |
| 用作外部事件计数器                       | TOC0n = 00H                                    |
| 用于清零&启动模式(通过TI00n引<br>脚有效沿输入进入) | 当使用检测TI01n 引脚有效沿时,禁止使用定时器输出(TO0n)。 TOC0n = 00H |
| 用作由运行定时器                        | _                                              |
| 用作PPG输出                         | 禁止为CR00n与CP01n设置相同的值或0000H。                    |
| 用作单脉冲输出                         | -                                              |
| 用于脉冲宽度测量                        | TOC0n = 00H                                    |

### (2) 定时器启动误差

定时器启动后,在产生匹配信号之前可能发生将近一个时钟周期的误差。这是由于启动 TMOn 计数操作与计数脉冲不同步引起的。

#### 图 7-60 TM0n 计数启动时序



### (3) CR00n 与 CR01n 的设置 (清零&启动模式(TM0n 与 CR00n 匹配时进入)

为 CR00n 与 CR01n 设置 0000H 以外的值 (当 TM0n 外部事件计数器时不能进行单脉冲计数)。

### (4) 捕捉寄存器数据保持时序

(a) 如果在读取 CR00n/CR01n 时,有效沿输入到 TI00n/TI01n 引脚并且检测到 TI00n 引脚脉冲的反向沿时, CR01n 执行捕捉操作但 CR00n/CR01n 的读取值不确定。此时当检测到 TI00n/TI01n 引脚的有效沿时产生中断 信号(INTTM00n/INTTM01n)(当检测到 TI00n 引脚的反向脉冲沿时不产生中断信号)。 如果由于检测到 TI00n/TI01n 引脚的有效沿而捕捉到计数值时,则应在产生 INTTM00n/INTTM01n 信号后读取 CR00n/CR01n 的值。



图 7-61 捕捉寄存器数据保持时序

(b) 当 16 位定时器/事件计数器 0n 停止操作后, CR00n 与 CR01n 的值不确定。

### (5) 有效沿的设置

当定时器停止操作时(TMC0n3 与 TMC0n2 = 00)设置 TI00n 引脚的有效沿。使用 ES0n0 与 ES0n1 设置有效沿。

### (6) 单脉冲的重新触发

必须确定在单脉冲输出模式下正在输出一个活动电平时,没有触发产生。而且必须在输出当前活动电平后输入下一个触发。

### (7) OVF0n 标志的操作

### (a) OVF0n 标志的设置 (1)

在以下情况下以及 TMOn 溢出时将 OVF0n 标志设置为 1。

选择清零&启动模式(在TMOn与CR00n匹配时进入)。

↓ 设置 CR00n = FFFFH.

当 TMOn 与 CR00n 匹配且 TMOn 从 FFFFH 变为 0000H 时 TMOn 被清零

#### 图 7-62 OVF0n 标志操作时序



#### (b) OVF0n 标志清零

即使在 TM0n 溢出后下一个计数时钟被计数之前(TM0n 的值变为 0001H 之前)将 OVF0n 标志清零(0), OVF0n 也会再次被设置为 1, 并且对其清零是无效的。

## (8) 单脉冲输出

在自由运行定时器模式下或者在清零&启动模式(通过 TI00n 引脚有效沿进入)下,单脉冲输出能正确操作。而在清零&启动模式(在 TM0n 与 CR00n 匹配时进入)下不能输出单脉冲。

#### (9) 捕捉操作

#### (a) 当指定 TI00n 的有效沿作为计数时钟时

当指定 TI00n 的有效沿作为计数时钟时, 捕捉寄存器(指定 TI00n 作为触发)不能正确操作。

#### (b) 通过 TI01n 与 TI00n 引脚输入信号准确捕捉计数值的脉冲宽度

为了准确捕捉计数值,作为捕捉触发的 TI00n 与 TI01n 引脚的输入脉冲宽度必须大于两个计数时钟(由 PRM0n 选择)(参见图 7-9)。

#### (c) 中断信号的产生

在计数时钟的下降沿进行捕捉操作,但中断信号(INTTM00n 与 INTTM01n)则在下一个计数时钟的上升沿产生。(参见图 7-9)。

#### (d) 当 CRC0n1 (捕捉/比较控制寄存器 0n (CRC0n)的第 1 位)=1 时的注意事项

在 TI00n 引脚输入信号的反向沿将 TM0n 的计数值捕捉到 CR00n 时,捕捉到计数值后不产生中断信号 (INTTM00n)。如果在此操作期间,从 TI01n 引脚检测到有效沿,则不执行捕捉操作但会产生中断信号 (INTTM00n)作为外部中断信号。当不使用外部中断时屏蔽 INTTM00n 信号。

#### (10) 脉冲沿检测

#### (a) 复位后指定有效沿

如果复位后 TI00n 或 TI01n 引脚处于高电平,且当指定上升沿或兼有两种脉冲沿作为 TI00n 或 TI01n 引脚的有效沿时,允许 16 位定时器/事件计数器 0n 的操作,则检测到 TI00n 或 TI01n 引脚的高电平作为上升沿。上拉 TI00n 或 TI01n 引脚时要特别注意。但如果操作停止之后又允许操作,则不检测上升沿。

#### (b) 采样时钟(用于消除噪音)

根据 TIOOn 的有效沿是用作计数时钟还是用作捕捉触发,采样时钟(用于消除噪音)会发生变化。在前一种情况中采样时钟恒为 fprs。而在后一种情况中则将由 PRMOn 选择的计数时钟用于采样。

当采样到 TI00n 引脚的输入信号并且在一个周期内两次检测到有效电平时,才认为检测到有效沿。因此可以消除窄脉冲宽度的噪音(参见图 7-9)。

#### (11) 定时器操作

无论 CPU 处于何种操作模式,当定时器停止操作时,不响应 TI00n/TI01n 引脚的输入信号。

#### **备注:** 1. fprs: 外部硬件时钟频率

**2.** n = 0, 1

## 第八章 8位定时器/事件计数器 50 和 51

## 8.1 8 位定时器/事件计数器 50 和 51 的功能

8位定时器/事件计数器 50 和 51 具有以下功能。

- 间隔定时器
- 外部事件计数器
- 方波输出
- PWM 输出

## 8.2 8 位定时器/事件计数器 50 和 51 的构成

8位定时器/事件计数器 50 和 51 包括以下硬件。

表 8-1 8 位定时器/事件计数器 50 和 51 的构成

| 项目     | 配置                                                                                                                |
|--------|-------------------------------------------------------------------------------------------------------------------|
| 定时器寄存器 | 8 位定时器计数器 5n (TM5n)                                                                                               |
| 寄存器    | 8 位定时器比较寄存器 5n (CR5n)                                                                                             |
| 定时器输入  | TI5n                                                                                                              |
| 定时器输出  | TO5n                                                                                                              |
| 控制寄存器  | 定时器时钟选择寄存器 5n (TCL5n)<br>8 位定时器模式控制寄存器 5n (TMC5n)<br>端口模式寄存器 1 (PM1)或端口模式寄存器 3 (PM3)<br>端口寄存器 1 (P1)或端口寄存器 3 (P3) |

图 8-1 与图 8-2 显示 8 位定时器/事件计数器 50 和 51 的框图

图 8-1 8 位定时器/事件计数器 50 的框图



图 8-2 8 位定时器/事件计数器 51 的框图



注: 1. 定时器输出 F/F

2. PWM 输出 F/F

### (1) 8 位定时器计数器 5n (TM5n)

TM5n 是一个 8 位寄存器,用于对计数脉冲进行计数,它是只读的。该计数器的计数值随计数时钟的上升沿同步增加。

#### 图 8-3 8 位定时器计数器 5n (TM5n)的格式



在以下几种情况下将计数值清零(00H)。

- <1> 产生复位信号
- <2> TCE5n 清零
- <3> 在 TM5n 与 CR5n 匹配时清零和启动模式中,当 TM5n 与 CR5n 匹配时。

#### (2) 8 位定时器比较寄存器 5n (CR5n)

可以由 8 位存储器操作指令对 CR5n 进行读写。

除了 PWM 模式外, CR5n 的值将与 8 位定时器计数器 5n(TM5n)的计数值频繁相比较,如果匹配将产生中断请求 (INTTM5n)。

在 PWM 模式下,TM5n 与 CR5n 的值匹配时,TO5n 输出非活动电平,但不产生中断信号。

CR5n 的取值范围为: 00H  $\sim$  FFH。

复位信号的产生将 CR5n 清零(00H)。

图 8-4 8 位定时器比较寄存器 5n (CR5n)的格式



注意事项: 1. 在 TM5n 与 CR5n (TMC5n6 = 0)匹配时清零和启动模式下,不要将其它值写入 CR5n。

2. 在 PWM 模式中,以至少 3 个计数时钟(由 TCL5n 选择时钟)的间隔对 CR5n 进行重写。

### 8.3 控制 8 位定时器/事件计数器 50 和 51 的寄存器

以下四种寄存器用于控制 8 位定时器/事件计数器 50 和 51。

- 定时器时钟选择寄存器 5n (TCL5n)
- 8位定时器模式控制寄存器 5n (TMC5n)
- 端口模式寄存器 1 (PM1)或端口模式寄存器 3 (PM3)
- 端口寄存器 1 (P1)或端口寄存器 3 (P3)

### (1) 定时器时钟选择寄存器 5n (TCL5n)

该寄存器设置 8 位定时器/事件计数器 5n 的计数时钟,和 Tl5n 引脚输入的有效沿。可由 1 位或 8 位存储器操作指令设置 TCL5n。 复位信号的产生将 TCL5n 清零(00H)。

### 备注: n = 0, 1

## 图 8-5 定时器时钟选择寄存器 50 (TCL50) 的格式

| 地址: FF6AF | · 复位后: 0 | 0H R/W |   |   |   |        |        |        |
|-----------|----------|--------|---|---|---|--------|--------|--------|
| 符号        | 7        | 6      | 5 | 4 | 3 | 2      | 1      | 0      |
| TCL50     | 0        | 0      | 0 | 0 | 0 | TCL502 | TCL501 | TCL500 |

| TCL502 | TCL501 | TCL500 | 计数时钟选择               |                          |                          |                           |                           |
|--------|--------|--------|----------------------|--------------------------|--------------------------|---------------------------|---------------------------|
|        |        |        |                      | f <sub>PRS</sub> = 2 MHz | f <sub>PRS</sub> = 5 MHz | f <sub>PRS</sub> = 10 MHz | f <sub>PRS</sub> = 20 MHz |
| 0      | 0      | 0      | TI50引脚下              | 降沿                       |                          |                           |                           |
| 0      | 0      | 1      | TI50 引脚上             | 升沿                       |                          |                           |                           |
| 0      | 1      | 0      | fprs                 | 2 MHz                    | 5 MHz                    | 10 MHz                    | 20 MHz                    |
| 0      | 1      | 1      | fprs/2               | 1 MHz                    | 2.5 MHz                  | 5 MHz                     | 10 MHz                    |
| 1      | 0      | 0      | fprs/2 <sup>2</sup>  | 500 kHz                  | 1.25 MHz                 | 2.5 MHz                   | 5 MHz                     |
| 1      | 0      | 1      | fprs/2 <sup>6</sup>  | 31.25 kHz                | 78.13 kHz                | 156.25 kHz                | 312.5 kHz                 |
| 1      | 1      | 0      | fprs/2 <sup>8</sup>  | 7.81 kHz                 | 19.53 kHz                | 39.06 kHz                 | 78.13 kHz                 |
| 1      | 1      | 1      | fprs/2 <sup>13</sup> | 0.24 kHz                 | 0.61 kHz                 | 1.22 kHz                  | 2.44 kHz                  |

注意事项: 1. 如果要向 TCL50 写入其它值,则必须提前停止定时器操作。

2. 必须将第3~7位清零。

备注: fprs: 外部设备时钟频率

图 8-6 定时器时钟选择寄存器 51 (TCL51) 的格式

 地址: FF8CH
 复位后: 00H
 R/W

 符号
 7
 6
 5
 4
 3
 2
 1
 0

 TCL51
 0
 0
 0
 0
 TCL512
 TCL511
 TCL511
 TCL510

| TCL512 | TCL511 | TCL510 | 计数时钟选择               |                          |                          |                           |                           |
|--------|--------|--------|----------------------|--------------------------|--------------------------|---------------------------|---------------------------|
|        |        |        |                      | f <sub>PRS</sub> = 2 MHz | f <sub>PRS</sub> = 5 MHz | f <sub>PRS</sub> = 10 MHz | f <sub>PRS</sub> = 20 MHz |
| 0      | 0      | 0      | TI51 下降沿             |                          |                          |                           |                           |
| 0      | 0      | 1      | TI51 上升沿             |                          |                          |                           |                           |
| 0      | 1      | 0      | f <sub>PRS</sub>     | 2 MHz                    | 5 MHz                    | 10 MHz                    | 20 MHz                    |
| 0      | 1      | 1      | fprs/2               | 1 MHz                    | 2.5 MHz                  | 5 MHz                     | 10 MHz                    |
| 1      | 0      | 0      | fprs/24              | 125 kHz                  | 312.5 kHz                | 625 kHz                   | 1.25 MHz                  |
| 1      | 0      | 1      | fprs/2 <sup>6</sup>  | 31.25 kHz                | 78.13 kHz                | 156.25 kHz                | 312.5 kHz                 |
| 1      | 1      | 0      | fprs/2 <sup>8</sup>  | 7.81 kHz                 | 19.53 kHz                | 39.06 kHz                 | 78.13 kHz                 |
| 1      | 1      | 1      | fprs/2 <sup>12</sup> | 0.49 kHz                 | 1.22 kHz                 | 2.44 kHz                  | 4.88 kHz                  |

注意事项: 1. 如果要向 TCL51 写入其它值,则必须提前停止定时器操作。

2. 必须将第3~7位清零。

**备注:** fprs: 外部设备时钟频率

### (2) 8 位定时器模式控制寄存器 5n (TMC5n)

TMC5n 主要执行以下五种设置操作。

<1> 8位定时器计数器 5n (TM5n)计数操作控制

<2> 8位定时器计数器 5n (TM5n)操作模式选择

<3> 定时器输出 F/F (flip flop 触发器)状态设置

<4> 定时器 F/F 控制或 PWM(自由运行)模式中活动电平的选择

<5> 定时器输出控制

可以由 1 位或 8 位存储器操作指令设置 TMC5n。

复位信号的产生将该寄存器清零(00H)。

备注: n = 0, 1

## 图 8-7 8 位定时器模式控制寄存器 50 (TMC50)的格式

地址: FF6BH 复位后: 00H R/W \*\*

符号 6 <2> <7> 4 <3> 1 <0> TMC50 TCE50 TMC506 LVS50 LVR50 TMC501 TOE50 0 0

| ĺ | TCE50 | TM50 计数操作控制         |
|---|-------|---------------------|
| I | 0     | 清零后,禁止计数操作(计数器停止操作) |
|   | 1     | 开始计数                |

| TMC506 | TM50 操作模式选择            |
|--------|------------------------|
| 0      | TM50 与 CR50 匹配时清零和启动模式 |
| 1      | PWM (自由运行)模式           |

| LVS50 | LVR50 | 定时器输出 F/F 状态设置                   |
|-------|-------|----------------------------------|
| 0     | 0     | 无变化                              |
| 0     | 1     | 定时器输出 F/F 复位(0) (TO50 默认输出: 低电平) |
| 1     | 0     | 定时器输出 F/F 设置(1) (TO50 默认输出: 高电平) |
| 1     | 1     | 禁止设置                             |

| TMC501 | 其他模式(TMC506 = 0) | PWM 模式(TMC506 = 1) |  |  |
|--------|------------------|--------------------|--|--|
|        | 定时器 F/F 控制       | 活动电平选择             |  |  |
| 0      | 禁止反转操作           | 高电平活动              |  |  |
| 1      | 允许反转操作           | 低电平活动              |  |  |

| TOE50 | 定时器输出控制            |
|-------|--------------------|
| 0     | 禁止输出 (TM50 输出为低电平) |
| 1     | 允许输出               |

注: 第2位和第3位为只写操作位。

(参见下页的注意事项和备注)

### 图 8-8 8 位定时器模式控制寄存器 51 (TMC51) 的格式

地址: FF43H 复位后: 00H R/W <sup>性</sup>

符号 TMC51

| <7>   | 6      | 5 | 4 | <3>   | <2>   | 1      | <0>   |
|-------|--------|---|---|-------|-------|--------|-------|
| TCE51 | TMC516 | 0 | 0 | LVS51 | LVR51 | TMC511 | TOE51 |

|                      | TCE51 | TM51 计数操作控制 |  |  |  |  |
|----------------------|-------|-------------|--|--|--|--|
| 0 清零后禁止计数操作(计数器停止操作) |       |             |  |  |  |  |
| 1 开始计数               |       | 开始计数        |  |  |  |  |

| TMC516 | TM51 操作模式选择            |  |  |  |  |
|--------|------------------------|--|--|--|--|
| 0      | TM51 与 CR51 匹配时清零和启动模式 |  |  |  |  |
| 1      | PWM (自由运行)模式           |  |  |  |  |

| LVS51 | LVR51 | 定时器输出 F/F 状态设置                   |  |  |
|-------|-------|----------------------------------|--|--|
| 0     | 0     | E变化                              |  |  |
| 0     | 1     | 定时器输出 F/F 复位 (0) (TO51 默认输出:低电平) |  |  |
| 1     | 0     | 定时器输出 F/F 设置 (1) (TO51 默认输出:高电平) |  |  |
| 1     | 1     | 禁止设置                             |  |  |

| TMC511 | 其他模式 (TMC516 = 0) | PWM 模式 (TMC516 = 1) |  |  |
|--------|-------------------|---------------------|--|--|
|        | 定时器 F/F 控制        | 活动电平选择              |  |  |
| 0      | 禁止反转操作            | 高电平活动               |  |  |
| 1      | 允许反转操作            | 低电平活动               |  |  |

| TOE51 | 定时器输出控制            |  |  |
|-------|--------------------|--|--|
| 0     | 类止输出 (TM51 输出为低电平) |  |  |
| 1     | 允许输出               |  |  |

注: 第2位和第3位为只写操作位。

注意事项: 1. 除 PWM 模式外,对 LVS5n 与 LVR5n 的设置有效。

2. 按下列顺序执行<1> ~ <4>,注意不能同时执行。

<1> 设置 TMC5n1, TMC5n6: 操作模式设置

<2> 设置 TOE5n, 允许输出: 允许定时器输出

<3> 设置 LVS5n, LVR5n (见注意事项 1): 定时器 F/F 设置

<4> 设置 TCE5n

3. 重写 TMC5n6 前,停止操作。

**备注:** 1. 在 PWM 模式中,将 TCE5n 清零可禁止 PWM 输出。

- 2. 读取 LVS5n 与 LVR5n 时,读取的值为 0。
- 3. 无论 TCE5n 取何值, TMC5n6、LVS5n、 LVR5n、 TMC5n1 和 TOE5n 的值都与 TO5n 引脚有关。
- 4. n = 0, 1

### (3) 端口模式寄存器 1 和 3 (PM1, PM3)

这两个寄存器用于按位设置端口1和3的输入输出操作模式。

当 P17/TO50/TI50 和 P33/TO51/TI51/INTP4 引脚用于定时器输出时,将 PM17 和 PM33 以及 P17 与 P33 的输出 锁存器清零。

当 P17/TO50/TI50 和 P33/TO51/TI51/INTP4 引脚用于定时器输入时,将 PM17 和 PM33 置 1,P17 与 P33 的输出锁存值可以为 0 也可以为 1。

可以由 1 位或 8 位存储器操作指令设置 PM1 和 PM3。

复位信号的产生将寄存器的内容设置为 FFH。

### 图 8-9 端口模式寄存器 1 (PM1) 的格式

地址: FF21H 复位后: FFH R/W

符号 7 6 5 3 2 1 0 4 PM1 PM17 PM16 PM15 PM14 PM13 PM12 PM11 PM10

| PM1n             | P1n 引脚 I/O 模式选择 (n = 0 ~ 7) |  |  |
|------------------|-----------------------------|--|--|
| 0 输出模式 (输出缓冲器打开) |                             |  |  |
| 1 输入模式 (输出缓冲器关闭) |                             |  |  |

### 图 8-10 端口模式寄存器 3 (PM3)的格式

地址: FF23H 复位后: FFH R/W

符号 7 6 5 3 2 0 4 1 PM3 1 1 PM33 PM32 PM31 PM30

| PM3n | P3n 引脚 I/O 模式选择(n = 0 $\sim$ 3) |  |  |  |  |
|------|---------------------------------|--|--|--|--|
| 0    | 0 输出模式 (输出缓冲器打开)                |  |  |  |  |
| 1    | 1 输入模式 (输出缓冲器关闭)                |  |  |  |  |

### 8.4 8 位定时器/事件计数器 50 和 51 的操作

#### 8.4.1 用作间隔定时器

8 位定时器/事件计数器 5n 用作间隔定时器,可以在间隔时间内不断产生中断请求,该间隔时间由 8 位定时器比较寄存器 5n(CR5n)的预置值决定。

当 8 位定时器计数器 5n(TM5n)中的计数值与 CR5n 中的值相匹配时,将 TM5n 清零并继续计数,同时产生中断请求信号(INTTM5n)。

根据定时器时钟选择寄存器 5n(TCL5n)的第 0~2 位(TCL5n0 ~ TCL5n2)选择 TM5n 的计数时钟。

## 设置

<1> 设置寄存器

• TCL5n: 设置计数时钟

• CR5n: 比较值

• TMC5n: 停止计数操作,选择 TM5n 与 CR5n 匹配时清零和启动模式。

(TMC5n = 0000×××0B, × = 不必考虑)

<2> 将 TCE5n 置 1 后, 开始计数。

<3> 如果 TM5n 与 CR5n 值匹配时,产生中断 INTTM5n (将 TM5n 清零(00H))。

<4> 以相同的时间间隔重复产生 INTTM5n。

将 TCE5n 清零, 停止计数操作。

### 注意事项:操作期间不要向 CR5n 写入其它值。

**备注:** 1. 如需了解如何允许 INTTM5n 中断,请参见第二十章 中断功能。

**2.** n = 0.1

图 8-11 间隔定时器操作的时序 (1/2)

#### (a) 基本操作



**备注:** 间隔时间 = (N + 1) × t N = 01H ∼ FEH n = 0, 1

图 8-11 间隔定时器操作的时序(2/2)

## (b) CR5n = 00H



## (c) CR5n = FFH



#### 8.4.2 用作外部事件计数器

外部事件计数器通过 8 位定时器计数器 5n (TM5n) 对输入到 TI5n 引脚的外部时钟脉冲计数。

TM5n 随输入的有效沿次数递增。有效沿由定时器时钟选择寄存器 5n (TCL5n)规定,可以选择上升沿或下降沿。

当 TM5n 中的计数值与 8 位定时器比较寄存器 5n(CR5n)中的值相匹配时,将 TM5n 清零,并产生中断请求信号 (INTTM5n)。

一旦 TM5n 中的值与 CR5n 的值匹配, 将产生 INTTM5n 中断请求。

### 设置

#### <1> 设置寄存器

- 设置端口模式寄存器 (PM17 或 PM33) \*\* 的值为 1。
- TCL5n: 选择 TI5n 引脚输入脉冲沿

TI5n 引脚下降沿 → TCL5n = 00H TI5n 引脚上升沿 → TCL5n = 01H

- CR5n: 比较值
- TMC5n:停止计数,选择 TM5n 与 CR5n 匹配时清零和启动模式,禁止定时器 F/F 反转操作,不允许定时器输出。

(TMC5n = 0000××00B × = 不必理会)

- <2> 当 TCE5n = 1 时,开始对从 TI5n 引脚输入的脉冲计数。
- <3> 当 TM5n 与 CR5n 的值匹配时,将产生 INTTM5n (TM5n 清零(00H))。
- <4> 在经过以上设置后,每当 TM5n 与 CR5n 的值匹配时都会产生 INTTM5n 中断请求。
- 注: 8 位定时器/事件计数器 50: PM17 8 位定时器/事件计数器 51: PM33
- 备注: 如需了解如何允许 INTTM5n 中断,请参见第二十章 中断功能。

## 图 8-12 外部事件计数器操作的时序 (规定上升沿有效)



备注:  $N = 00H \sim FFH$ n = 0, 1

#### 8.4.3 方波输出操作

以8位定时器比较寄存器5n(CR5n)的预置值决定的间隔时间输出任选频率的方波。

通过将 8 位定时器模式控制寄存器 5n(TMC5n)的第 0 位(TOE5n)置 1,可以在规定的间隔时间内反转 TO5n 引脚输出的状态,该间隔时间由 8 位定时器比较寄存器 5n(CR5n)的预置值决定。这样,可以输出任选频率的方波(占空比=50%)。

## 设置

#### <1> 设置寄存器

• 端口输出锁存器 (P17 或 P33) 和端口模式寄存器 (PM17 或 PM33) 清零。

• TCL5n: 选择计数时钟

• CR5n: 比较值

• TMC5n: 停止计数,选择 TM5n 与 CR5n 匹配时清零和启动模式

| LVS5n | LVR5n | 定时器输出 F/F 状态设置                       |  |  |
|-------|-------|--------------------------------------|--|--|
| 1     | 0     | 定时器输出 F/F 清零(0) (TO50 引脚的默认输出值:低电平)  |  |  |
| 0     | 1     | 定时器输出 F/F 置 (1) (TO50 引脚的默认输出值: 高电平) |  |  |

允许定时器输出

(TMC5n = 00001011B 或 00000111B)

- <2> 一旦 TCE5n = 1, 便开始计数。
- <3> 通过 TM5n 与 CR5n 的匹配,反转定时器输出 F/F。产生 INTTM5n 后,将 TM5n 清零(00H)。
- <4> 在经过以上设置后,在相同间隔内反转定时器输出 F/F,并从 TO5n 输出方波。 频率如下。

频率 = 1/2t (N + 1)

(N: 00H  $\sim$  FFH)

**注:** 8 位定时器/事件计数器 50: P17, PM17 8 位定时器/事件计数器 51: P33, PM33

#### 注意事项:操作期间不要向 CR5n 写入其它值。

**备注:** 1. 如需了解如何允许 INTTM5n 中断,请参见第二十章 中断功能。

**2.** n = 0, 1

### 图 8-13 方波输出操作的时序



注: 由 8 位定时器模式控制寄存器 5n(TMC5n)的第 2、3 位(LVR5n, LVS5n)设置 TO5n 的初始值。

### 8.4.4 PWM 输出操作

当 8 位定时器模式控制寄存器 5n(TMC5n)的第 6 位(TMC5n6)置 1 时,8 位定时器/事件计数器 5n 作为 PWM 输出使用。

占空比由 8 位定时器比较寄存器 5n(CR5n)的值决定,并从 TO5n 引脚输出。

设置 CR5n 为 PWM 脉冲的活动电平宽度;可以由 TMC5n 的第 1 位(TMC5n1)选择活动电平。

由定时器时钟选择寄存器 5n(TCL5n)的第  $0\sim2$  位( $TCL5n0\sim TCL5n2$ )选择计数时钟。

可以由 TMC5n 的第 0 位(TOE5n)决定 PWM 输出允许/禁止。

注意事项: 在 PWM 模式中, 当对 CR5n 进行重写时,需要至少 3 个计数时钟(该计数时钟由 TCL5n 选择)周期的写间隔。

### (1) PWM 输出的基本操作

## 设置

<1> 设置寄存器

• TCL5n: 选择计数时钟

• CR5n: 比较值

• TMC5n: 停止计数操作,选择 PWM 模式

定时器输出 F/F 不改变。

| TMC5n1 | 活动电平选择 |
|--------|--------|
| 0      | 高电平活动  |
| 1      | 低电平活动  |

允许定时器输出

(TMC5n = 01000001B 或 01000011B)

<2> 当 TCE5n = 1 时,计数开始。
TCE5n 清零可以停止计数操作。

注: 8 位定时器/事件计数器 50: P17, PM17 8 位定时器/事件计数器 51: P33, PM33

### PWM 输出操作

- <1> PWM 输出(从 TO5n 输出)一直输出非活动电平,直至产生溢出。
- <2> 当发生溢出时,输出活动电平。直至 CR5n 与 8 位定时器计数器 5n (TM5n)的计数值匹配时才停止输出活动电平。
- <3> 若 CR5n 与计数值匹配,将输出非活动电平直至溢出再次发生。
- <4> 重复 <2>和 <3>的操作,直至计数停止。
- <5> 当 TCE5n=0 停止计数时,PWM 输出非活动电平。

需要了解时序的详细信息,参见图 8-14 和 8-15。

周期、活动电平宽度和占空比如下。

- 周期 = 2<sup>8</sup>t
- 活动电平宽度 = Nt
- 占空比 = N/2<sup>8</sup>

 $(N = 00H \sim FFH)$ 

### 图 8-14 PWM 输出操作的时序

#### (a) 基本操作(活动电平 = H)



## (b) CR5n = 00H



#### (c) CR5n = FFH



**备注:** 1. 图 8-14 (a)中的<1> ~ <3> 和 <5> 与 **8.4.4 (1) PWM 输出基本操作**的 PWM 输出操作 中<1> ~ <3> 和 <5> 相对应。

**2.** n = 0, 1

### (2) 当 CR5n 改变时的操作

图 8-15 改变 CR5n 时的操作时序

(a) 在计数值为 FFH 时,时钟上升沿出现之前,CR5n 的值由 N 变为 M →改变后,溢出时立即将值传送至 CR5n。



(b) 在计数值为 FFH 时,时钟上升沿出现之后,CR5n 的值由 N 变为 M  $\rightarrow$  当出现第 2 次溢出时将值传送至 CR5n。



注意事项:图 8-15<1>与<2>之间读取 CR5n 时,读取的值与实际值不同(读取的值:M, CR5n 实际值:N)。

# 8.5 使用 8 位定时器/事件计数器 50 和 51 的注意事项

## (1) 定时器启动误差

定时器启动后,在产生匹配信号之前可能发生将近一个时钟周期的误差。 这是由于 8 位定时器计数器 50 和 51(TM50, TM51)的启动与计数时钟不同步引起的。

图 8-16 8 位定时器计数器 5n 启动的时序



## 第九章 8位定时器 H0 和 H1

## 9.1 8 位定时器 H0 和 H1 的功能

8位定时器 H0和 H1的功能如下。

- 间隔定时器
- 方波输出
- PWM 输出模式
- 载波发生器模式 (仅用于 8 位定时器 H1)

## 9.2 8 位定时器 H0 和 H1 的配置

8位定时器 H0 和 H1 包括以下硬件

表 9-1 8 位定时器 H0 和 H1 的配置

| 项目     | 配置                                                                                                       |  |  |  |  |  |
|--------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 定时器寄存器 | 8 位定时器计数 Hn                                                                                              |  |  |  |  |  |
| 寄存器    | 8 位定时器 H 比较寄存器 On (CMPOn)                                                                                |  |  |  |  |  |
|        | 8 位定时器 H 比较寄存器 1n (CMP1n))                                                                               |  |  |  |  |  |
| 定时器输出  | TOHn,输出控制器                                                                                               |  |  |  |  |  |
| 控制寄存器  | 8 位定时器 H 模式寄存器 n (TMHMDn)<br>8 位定时器 H 载波控制寄存器 1 (TMCYC1) <sup>推</sup><br>端口模式寄存器 1 (PM1)<br>端口寄存器 1 (P1) |  |  |  |  |  |

注: 仅用于8位定时器H1

备注: n = 0, 1

图 9-1 和 9-2 为定时器框图。



图 9-1 8 位定时器 H0 的框图



图 9-2 8 位定时器 H1 的框图

#### ★ (1) 8 位定时器 H 比较寄存器 0n (CMP0n)

该寄存器可由8位存储器操作指令进行读写。该寄存器用于所有的定时器操作模式。

该寄存器不断地将 CMP0n 的值和 8 位定时器计数器 Hn 的计数值进比较,并且当两个值匹配时,产生一个中断请求信号(INTTMHn)并反转 TOHn 的输出。

当定时器停止时(TMHEn = 0)重写 CMP0n 的值。

复位信号的产生将该寄存器设置为 00H。

图 9-3 8 位定时器 H 比较寄存器 0n (CMP0n)的格式

| 地址: FF18H(CMP00), FF1AH(CMP01) |   |   |   |   | 复位后: 0 | 0H R/W |   |   |
|--------------------------------|---|---|---|---|--------|--------|---|---|
| 符号                             | 7 | 6 | 5 | 4 | 3      | 2      | 1 | 0 |
| CMP1n<br>(n = 0, 1)            |   |   |   |   |        |        |   |   |

注意事项: CMP0n 在定时器计数操作期间不能被重写。

### ★ (2) 8 位寄存器 H 比较寄存器 1n (CMP1n)

可由8位存储器操作指令读写该寄存器。该寄存器用于PWM输出模式和载波发生器模式。

在 PWM 输出模式中,该寄存器不断地将 CMP1n 的设置值和 8 位定时器计数器 Hn 的计数值进行比较,当两个值匹配时,反转 TOHn 的输出。不产生中断请求信号。

在载波发生器模式中,CMP1n 寄存器不断地将 CMP1n 的设置值和 8 位定时器计数器 Hn 的计数值进行比较,如果两个值匹配,则产生一个中断请求信号(INTTMHn)。同时,计数值清零。

可以在定时器计数期间对 CMP1n 进行重写。

如果在定时器操作期间重写 CMP1n 的值,则当定时器计数器的值和 CMP1n 以前的值相匹配时,锁存新的值并传输给 CMP1n,然后 CMP1n 的值用新值取代。如果计数值和 CMP1n 值的匹配操作与 CMP1n 的写操作发生冲突,那么 CMP1n 的值将保持不变。

复位信号的产生对该寄存器清零(00H)。

图 9-4. 8 位定时器 H 比较寄存器 1n 的格式



注意事项: 在 PWM 输出模式和载波发生器模式下,当停止定时器计数操作(TMHEn = 0)后再启动定时器计数操作 (TMHEn = 1)时,必须设置 CMP1n (即使对 CMP1n 设置相同的值也要再设置一次)。

## 9.3 控制 8 位定时器 H0 和 H1 的寄存器

以下四个寄存器用于控制 8 位定时器 H0 和 H1。

- 8位定时器 H 模式寄存器 n (TMHMDn)
- 8位定时器 H 载波控制寄存器 1 (TMCYC1) \*\*
- 端口模式寄存器 1 (PM1)
- 端口寄存器 1 (P1)

注: 仅用于8位定时器H1

## (1) 8位定时器 H 模式寄存器 n (TMHMDn)

该寄存器用于控制定时器 H 的模式。 可以由 1 位或 8 位存储器操作指令设置该寄存器。 复位信号的产生对寄存器清零(00H)。

### 图 9-5 8 位定时器 H 模式寄存器 0 (TMHMD0) 的格式

地址: FF69H 复位后: 00H R/W

| TMHE0 | 是否允许定时器操作            |
|-------|----------------------|
| 0     | 停止定时器计数操作(计数器清零)     |
| 1     | 允许定时器计数(由输入时钟启动计数操作) |

| CKS02 | CKS01 | CKS00 | 计数时钟选择               |                          |                          |                           |                           |
|-------|-------|-------|----------------------|--------------------------|--------------------------|---------------------------|---------------------------|
|       |       |       |                      | f <sub>PRS</sub> = 2 MHz | f <sub>PRS</sub> = 5 MHz | f <sub>PRS</sub> = 10 MHz | f <sub>PRS</sub> = 20 MHz |
| 0     | 0     | 0     | fprs                 | 2 MHz                    | 5 MHz                    | 10 MHz                    | 20 MHz                    |
| 0     | 0     | 1     | fprs/2               | 1 MHz                    | 2.5 MHz                  | 5 MHz                     | 10 MHz                    |
| 0     | 1     | 0     | fprs/2 <sup>2</sup>  | 500 kHz                  | 1.25 MHz                 | 2.5 MHz                   | 5 MHz                     |
| 0     | 1     | 1     | fprs/26              | 31.25 kHz                | 78.13 kHz                | 156.25 kHz                | 312.5 kHz                 |
| 1     | 0     | 0     | fprs/2 <sup>10</sup> | 1.95 kHz                 | 4.88 kHz                 | 9.77 kHz                  | 19.54 kHz                 |
| 1     | 0     | 1     | TM50 2               | 输出**                     |                          |                           | ·                         |
|       | 其它情况  |       |                      | 禁止设                      | 置                        |                           |                           |

| TMMD01 | TMMD00 | 定时器操作模式  |
|--------|--------|----------|
| 0      | 0      | 间隔定时器模式  |
| 1      | 0      | PWM 输出模式 |
| 其它情况   |        | 禁止设置     |

| TOLEV0 | 定时器输出电平控制 (默认模式) |
|--------|------------------|
| 0      | 低电平              |
| 1      | 高电平              |

| TOEN0 | 定时器输出控制 |
|-------|---------|
| 0     | 禁止输出    |
| 1     | 允许输出    |

注: 在选择 TM50 输出作为计数时钟时,应注意以下几点。

- TM50 和 CR50 的值相匹配时产生清零&启动模式(TMC506 = 0), 先启动 8 位定时器/事件计数器 50, 然后允许定时器进行 F/F 反转操作(TMC501 = 1)

在任何模式中都不必将 TO50 作为定时器输出引脚。

注意事项: 1. 当 TMHE0=1 时,禁止设置 TMHMD0 的其他位。

2. 在 PWM 输出模式中,当定时器停止计数后(TMHE0=0)再次启动计数操作时(TMHE0=1), 必须设置 8 位定时器 H 比较寄存器 10(CMP10)的值(即使设置的是相同的值,也必须再次设置)。

**备注: 1. f**PRS: 外部硬件时钟频率

2. TMC506: 8 位定时器模式控制寄存器 50 (TMC50) 的第 6 位

TMC501: TMC50 的第 1 位

### 图 9-6 8 位定时器 H 模式寄存器 1 (TMHMD1) 的格式

地址: FF6CH 复位后: 00H R/W

TMHMD1

| <7>   | 6     | 5     | 4     | 3      | 2      | <1>    | <0>   |
|-------|-------|-------|-------|--------|--------|--------|-------|
| TMHE1 | CKS12 | CKS11 | CKS10 | TMMD11 | TMMD10 | TOLEV1 | TOEN1 |

| TMHE1 | 是否允许定时器操作            |
|-------|----------------------|
| 0     | 停止定时器计数操作(计数器清零)     |
| 1     | 允许定时器计数(由输入时钟启动计数操作) |

| CKS12 | CKS11 | CKS10 | 计数时钟选择                          |                          |                          |                           |                           |
|-------|-------|-------|---------------------------------|--------------------------|--------------------------|---------------------------|---------------------------|
|       |       |       |                                 | f <sub>PRS</sub> = 2 MHz | f <sub>PRS</sub> = 5 MHz | f <sub>PRS</sub> = 10 MHz | f <sub>PRS</sub> = 20 MHz |
| 0     | 0     | 0     | fprs                            | 2 MHz                    | 5 MHz                    | 10 MHz                    | 20 MHz                    |
| 0     | 0     | 1     | fprs/2 <sup>2</sup>             | 500 kHz                  | 1.25 MHz                 | 2.5 MHz                   | 5 MHz                     |
| 0     | 1     | 0     | fprs/24                         | 125 kHz                  | 312.5 kHz                | 625 kHz                   | 1.25 MHz                  |
| 0     | 1     | 1     | fprs/26                         | 31.25 kHz                | 78.13 kHz                | 156.25 kHz                | 312.5 kHz                 |
| 1     | 0     | 0     | fprs/2 <sup>12</sup>            | 0.49 kHz                 | 1.22 kHz                 | 2.44 kHz                  | 4.88 kHz                  |
| 1     | 0     | 1     | f <sub>RL</sub> /2 <sup>7</sup> | 1.88 kHz (               | TYP.)                    |                           |                           |
| 1     | 1     | 0     | f <sub>RL</sub> /2 <sup>9</sup> | 0.47 kHz (TYP.)          |                          |                           |                           |
| 1     | 1     | 1     | f <sub>RL</sub>                 | 240 kHz (TYP.)           |                          |                           |                           |

| TMMD11 | TMMD10 | 定时器操作模式  |  |  |
|--------|--------|----------|--|--|
| 0      | 0      | 间隔定时器模式  |  |  |
| 0      | 1      | 载波发生器模式  |  |  |
| 1      | 0      | PWM 输出模式 |  |  |
| 1      | 1      | 禁止设置     |  |  |

| TOLEV1 |     | 定时器输出电平控制 (默认模式) |
|--------|-----|------------------|
| 0      | 低电平 |                  |
| 1      | 高电平 |                  |

| TOEN1 | 定时器输出控制 |
|-------|---------|
| 0     | 禁止输出    |
| 1     | 允许输出    |

注意事项: 1. 当 TMHE1=1 时,禁止设置 TMHMD1 的其他位。

- 2. 在 PWM 输出模式和载波发生模式中,当定时器停止计数后(TMHE=0)再次启动计数器操作时 (TMHE1=1),必须设置 8 位定时器 H 比较寄存器 11 (CMP11) 的值(即使设置的是相同的值,也 必须再次设置)。
- 3. 当使用载波发生器模式时,设置 TMH1 的计数时钟频率至少是 TM51 计数时钟频率的 6 倍。

备注: 1. fprs: 外部硬件时钟频率

2. fRL: 内部低速振荡时钟频率

### (2) 8 位定时器 H 载波控制寄存器 1 (TMCYC1)

该寄存器用于控制 8 位定时器 H1 的遥控输出和载波脉冲输出状态。

可以由1位或8位存储器操作指令设置该寄存器。

复位信号的产生对寄存器清零(00H)。

#### 图 9-7 8 位定时器 H 载波控制寄存器 1 (TMCYC1) 的格式

地址: FF6DH 复位后: 00H R/W \*\*

7 6 5 4 3 2 1 <0>
TMCYC1 0 0 0 0 RMC1 NRZB1 NRZI

| RMC1 | NRZB1 | 遥控输出   |
|------|-------|--------|
| 0    | 0     | 低电平输出  |
| 0    | 1     | 高电平输出  |
| 1    | 0     | 低电平输出  |
| 1    | 1     | 载波脉冲输出 |

| NRZ1 | 载波脉冲输出状态标志                                |  |  |  |  |  |
|------|-------------------------------------------|--|--|--|--|--|
| 0    | 禁止载波输出状态(低电平状态)                           |  |  |  |  |  |
| 1    | 允许载波输出状态<br>(RMC1=1: 载波脉冲输出,RMC1=0: 高电平状态 |  |  |  |  |  |

#### 注: 第0位只读。

### (3) 端口模式寄存器 1 (PM1)

该寄存器按位设置端口1为输入输出操作模式。

在将 P15/TOH0 和 P16/TOH1/INTP5 引脚用于定时器输出时,需对 PM15 和 PM16 以及 P15 和 P16 的输出锁存器清零(0)。

可以由1位或8位存储器操作指令设置PM1。

复位信号的产生将寄存器置 FFH。

### 图 9-8 端口模式寄存器 1 (PM1) 的格式

地址: FF21H 复位后: FFH R/W

符号 7 5 3 2 1 0 PM1 PM17 PM14 PM13 PM12 PM16 PM15 PM11 PM10

|   | PM1n | P1n 引脚 I/O 模式 选择 (n = 0 $\sim$ 7) |  |  |  |  |  |
|---|------|-----------------------------------|--|--|--|--|--|
| ſ | 0    | 输出模式 (输出缓冲器打开)                    |  |  |  |  |  |
| ſ | 1    | 输入模式 (输入缓冲器关闭)                    |  |  |  |  |  |

### 9.4 8位定时器 H0 和 H1 的操作

#### 9.4.1 间隔定时器/方波输出操作

当 8 位定时器计数器 Hn 与比较寄存器 On(CMPOn)匹配时,将产生中断请求信号(INTTMHn)并对 8 位定时器计数器 Hn 清零(00H)。

在间隔定时器模式中不使用比较寄存器 1n(CMP1n)。即使 CMP1n 寄存器已赋值,也不会检测 8 位定时器计数器 Hn 与 CMP1n 寄存器的匹配情况,所以不影响定时器的输出。

通过将定时器 H 模式寄存器 n(TMHMDn)的第 0 位(TOENn)置 1,可以从 TOHn 输出任意频率的方波(占空比 = 50%)。

设置

<1> 寄存器设置。

### 图 9-9 间隔定时器/方波输出操作期间的寄存器设置

#### (i) 设置定时器 H 模式寄存器 n (TMHMDn)



#### (ii) CMP0n 寄存器设置

如果 N 作为比较值,则时间间隔如下:

- 时间间隔 = (N +1)/fcnT
- <2> 当 TMHEn = 1 时, 开始计数。
- <3> 当 8 位定时器计数器 Hn 与 CMP0n 的值匹配时,将产生 INTTMHn 信号,并对 8 位定时器计数器 Hn 清零 (00H)。
- <4> 随后,以相同的间隔时间重复产生 INTTMHn 信号。若要停止计数操作,则将 TMHEn 清零(0)。
- 备注: 1. 如需了解输出引脚的设置情况,参见 9.3 (3) 端口模式寄存器 1 (PM1)。
  - 2. 如需了解允许 INTTMHn 信号中断的情况,可参见第二十章 中断功能。
  - **3.** n = 0, 1

### 图 9-10 间隔定时器/方波输出操作时序(1/2)

### (a) 基本操作 (当01H≤CMP0n≤FEH 时的操作)



- <1> 通过将 TMHEn 置 1,允许计数操作。一旦允许计数,则在不到 1 个时钟周期的时间内启动计数操作。
- <2> 当8位定时器计数器 Hn 与 CMP0n 寄存器的值匹配时,将该定时器计数器清零并反转 TOHn 的输出电平。此外在计数时钟的上升沿输出 INTTMHn 信号。
- <3> 在定时器 Hn 操作期间将 TMHEn 位清零,设置 INTTMHn 信号和 TOHn 的输出为默认电平。如果在将 TMHEn 位清零(0)前它们已经处于默认电平,则电平保持不变。

**备注:** n = 0, 1 01H ≤ N ≤ FEH

## 图 9-10 间隔定时器/方波输出操作时序 (2/2)

## (b) 当 CMP0n = FFH 时的操作



### (c) 当 CMP0n = 00H 时的操作



#### 9.4.2 PWM 输出操作

在 PWM 输出模式中,可以输出具有任意占空比和周期的脉冲。

- 8 位定时器比较寄存器 0n(CMP0n)用于控制定时器输出(TOHn)的周期。禁止在定时器操作期间修改 CMP0n 寄存器的值。
- 8 位定时器比较寄存器 1n(CMP1n)用于控制定时器输出(TOHn)的占空比。允许在定时器操作期间修改 CMP1n 寄存器的值。

PWM 输出模式中的操作如下所示。

在定时器开始计数后,当 8 位定时器计数器 Hn 与 CMP0n 寄存器的值匹配时,反转 TOHn 的输出电平且清零 8 位定时器计数器 Hn。当 8 位定时器计数器 Hn 与 CMP1n 寄存器的值匹配时,反转 TOHn 的输出电平。

设置

<1> 寄存器设置。

### 图 9-11 PWM 输出模式下的寄存器设置

### (i) 设置定时器 H 模式寄存器 n (TMHMDn)



#### (ii) 设置寄存器 CMP0n

• 比较值(N): 周期设置

#### (iii) 设置寄存器 CMP1n

• 比较值(M): 占空比设置

**备注** 1. n = 0, 1

2.  $00H \le CMP1n (M) < CMP0n (N) \le FFH$ 

- <2> 当 TMHEn = 1 时, 开始计数。
- <3> CMP0n 是在允许计数操作后首次被比较的比较寄存器。当 8 位定时器计数器 Hn 与 CMP0n 寄存器的值匹配时,将 8 位定时器计数器 Hn 清零、产生中断请求信号(INTTMHn),并且反转 TOHn 输出电平。同时切换比较寄存器(与 8 位定时器比较的寄存器):由 CMP0n 改为 CMP1n。
- <4> 当8位定时器计数器 Hn 与 CMP1n 寄存器匹配时,反转 TOHn 输出电平,并切换比较寄存器(与8位定时器比较的寄存器):由 CMP1n 改为 CMP0n。此时不对8位定时器计数器 Hn 清零,也不产生 INTTMHn 信号.

- <5> 重复执行过程<3>和<4>,可以获取具有任意占空比的脉冲。
- <6> 若要停止计数操作,则设置 TMHEn = 0。

若 CMP0n 的值为 N、CMP1n 的值为 M, 计数时钟频率为 fcnr,则 PWM 脉冲的输出周期和占空比如下所示。

- PWM 脉冲输出周期 = (N + 1)/fcnT
- 占空比 = (M + 1)/(N + 1)
- 注意事项: 1. 可以在定时器计数操作时改变 CMP1n 的设置值。但从改变 CMP1n 寄存器的值到这个值被传输给寄存器需要经历三个操作时钟(通过 TMHMDn 寄存器的 CKSn2 到 CKSn0 位选择的时钟信号)
  - 2. 在定时器计数操作停止后(TMHEn=0),再次启动定时器操作时(TMHEn=1),必须对 CMP1n 进行设置(即使是设置相同的值,也必须重新设置 CMP1n 寄存器)
  - 3. CMP1n 寄存器的设置值(M)和 CMP0n 寄存器的设置值(N)必须在以下范围内取值。 00H ≤ CMP1n (M) < CMP0n (N) ≤ FFH
- 备注: 1. 如需了解输出引脚的设置,参见 9.3 (3) 端口模式寄存器 1 (PM1)。
  - 2. 要了解允许 INTTMHn 信号中断的情况,可参见第二十章 中断功能。
  - **3.** n = 0, 1

### 图 9-12 PWM 输出模式下的时序操作(1/4)

## (a) 基本操作



- <1> 通过设置 TMHEn =1,允许计数操作。通过屏蔽一个计数时钟,启动 8 位定时器计数器 Hn。此时,TOHn 输出保持默认电平状态。
- <2> 当 8 位定时器计数器 Hn 与 CMP0n 匹配时将 TOHn 的输出电平反转,对 8 位定时器计数器 Hn 清零,并输出 INTTMHn 中断信号。
- <3> 当 8 位定时器计数器 Hn 与 CMP1n 匹配时,反转 TOHn 的输出电平。而此时并不对 8 位定时器计数器 Hn 清零,也不输出 INTTMHn 中断信号。
- <4> 在定时器 Hn 操作期间若将 TMHEn 位清零,可以设置 INTTMHn 信号和 TOHn 输出电平为默认值。

## 图 9-12 PWM 输出模式下的时序操作(2/4)

## (b) 当 CMP0n = FFH, CMP1n = 00H 时的操作



## (c) 当 CMP0n = FFH, CMP1n = FEH 时的操作



# 图 9-12 PWM 输出模式下的时序操作(3/4)

# (d) 当 CMP0n = 01H, CMP1n = 00H 时的操作



#### 图 9-12 PWM 输出模式下的时序操作 (4/4)

#### (e) 修改 CMP1n 的时序操作 (CMP1n = 02H → 03H, CMP0n = A5H)



- <1> 通过设置 TMHEn =1 允许计数操作。通过屏蔽 1 个计数时钟,启动 8 位定时器计数器 Hn。此时 TOHn 输出保持默认电平状态。
- <2> 在定时器计数器操作期间可以修改 CMPIn 的值。修改操作与计数时钟不同步。
- <3> 当8位定时器计数器 Hn与 CMP0n的值匹配时,将8位定时器计数器 Hn的值清零、反转 TOHn输出电平,并输出 INTTMHn信号。
- <4> 如果 CMPIn 的值被修改,则修改后的值被锁存,且不传送到寄存器。当 8 位定时器计数器 Hn 的值与修改前 CMPIn 寄存器的值匹配时,则将值传送至 CMPIn,这样 CMPIn 的值就被修改了(<2>')。 但从 CMPIn 的值被修改到将值传送至寄存器至少需要 3 个计数时钟。如果在 3 个计数时钟内产生一个匹配信号,则不能将修改后的值传送至寄存器。
- <5> 当8位定时器计数器 Hn的值与修改后的 CMP1n的值匹配时,反转 TOHn输出电平。此时不对8位定时器计数器 Hn清零,也不产生 INTTMHn信号。
- <6> 在定时器 Hn 操作期间若将 TMHEn 位清零,可以设置 INTTMHn 信号和使 TOHn 输出电平为默认值。

# 9.4.3 载波发生器操作 (仅用于 8 位定时器 H1)

★ 在载波发生器模式中 8 位定时器 H1 用于产生红外遥控器的载波信号,8 位定时器/事件计数器 51 用于红外遥控信号的产生(计时)

以8位定时器/事件计数器51设置的周期输出载波时钟。该载波时钟由8位定时器H1产生。

在载波发生器模式中,8位定时器 H1 载波脉冲由8位定时器/事件计数器51控制输出,并从TOH1输出。

## (1) 载波的发生

在载波发生器模式中,8位定时器 H 比较寄存器 01 (CMP01)产生低电平宽度的载波脉冲波形,而8位定时器 H 比较寄存器 11 (CMP11)产生高电平宽度的载波脉冲波形。

在8位定时器 H1 操作期间允许修改 CMP11, 但禁止修改 CMP01。

#### (2) 载波输出控制

载波输出由 8 位定时器/事件计数器 51 的中断请求信号(INTTM51)和 8 位定时器 H 载波控制寄存器(TMCYC1)的 NRZB1 和 RMC1 位控制。输出之间的关系如下所示。

| RMC1 位 | NRZB1 位 | 输出     |
|--------|---------|--------|
| 0      | 0       | 低电平输出  |
| 0      | 1       | 高电平输出  |
| 1      | 0       | 低电平输出  |
| 1      | 1       | 载波脉冲输出 |

为了在计数操作期间控制载波脉冲输出,TMCYC1 寄存器的 NRZ1 和 NRZB1 位有 1 个主位和从位配置。NRZ1 位只读,而 NRZB1 位可读可写。INTTM51 信号与 8 位定时器 H1 计数时钟同步,且作为 INTTM5H1 信号输出。INTTM5H1 信号作为 NRZ1 位的数据传送信号,且 NRZB1 位的值被传送至 NRZ1 位。从 NRZB1 位传送至 NRZ1 位的时序如下所示。



图 9-13 传送时序

- <1> INTTM51 信号与 8 位定时器 H1 的计数时钟同步,并作为 INTTM5H1 信号输出。
- <2> 在 INTTM5H1 信号上升沿的第 2 个时钟处将 NRZB1 位的值传送至 NRZ1 位。
- <3> 在中断服务程序中将下一个值写入 NRZB1 位。该中断服务程序已由 INTTM5H1 中断启动或通过轮询中断请求标志检测到时序后启动。将下一次要计数的值写入 CR51 中。
- 注意事项: 1. NRZB1 位被重写后至少到第 2 个时钟时才能被再次重写, 否则, 从 NRZB1 位到 NRZ1 位的传送不能得到保证。
  - 2. 在载波发生器模式中使用 8 位定时器/事件计数器 51 时,在<1>时刻将产生中断。如果在其他模式中使用 8 位定时器/事件计数器 51,中断产生的时序则不相同。

设置

<1> 寄存器设置

#### 图 9-14 在载波发生器模式下的寄存器设置

#### (i) 设置 8 位定时器 H 模式寄存器 1 (TMHMD1)



#### (ii) CMP01 寄存器设置

• 比较值

#### (iii) CMP11 寄存器设置

• 比较值

#### (iv) TMCYC1 寄存器设置

- RMC1 = 1 ... 遥控输出允许位
- NRZB1 = 0/1 ... 载波输出允许位

#### (v) TCL51 和 TMC51 寄存器设置

• 参见 8.3 控制 8 位定时器/事件计数器 50 和 51 的寄存器。

- <2> 当 TMHE1 = 1 时,8 位定时器 H1 开始计数。
- <3> 当8位定时器模式控制寄存器51(TMC51)的TCE51=1时,8位定时器/事件计数器51开始计数。
- <4> 允许计数后,第1个用于比较的比较寄存器是CMP01。当8位定时器计数器H1的计数值与CMP01的值匹配时,将产生INTTMH1信号,并对8位定时器计数器H1清零,而此时与8位定时器计数器比较的比较寄存器从CMP01被切换为CMP11。
- <5> 当8位定时器计数器 H1的计数值与 CMP11寄存器的值匹配时,将产生 INTTMH1信号,并对8位定时器计数器 H1清零,而此时与8位定时器计数器比较的比较寄存器从CMP11被切换为CMP01。
- <6> 重复执行过程<4>和<5>,将产生1个载波时钟。
- <7> INTTM51 信号与 8 位定时器 H1 的计数时钟同步,并作为 INTTM5H1 信号输出。INTTM5H1 信号作为 NRZB1 位的数据传输信号,并将 NRZB1 位的值传送至 NRZ1 位。
- ★ <8> 在中断服务程序中将下一个值写入 NRZB1 位。该中断服务程序已由 INTTM5H1 中断启动或通过轮询中断请求标志检测到时序后启动。将下一次要计数的值写入 CR51 中。
  - <9> 当 NRZ1 位是高电平时,将从 TOH1 引脚输出载波时钟。

<10> 通过执行上述过程,可以获得任意形式的载波时钟。若要停止计数操作,可以将 TMHE1 清零。

如果 CMP01 的值为 N、CMP11 的值为 M、计数时钟频率为 fcnr,则载波时钟输出周期与占空比如下所示。

- 载波时钟输出周期 = (N + M + 2)/fcnT
- 占空比=高电平宽度/ 载波时钟输出宽度 = (M+1)/(N+M+2)
- 注意事项: 1. 在定时器计数操作停止后(TMHE1=0),再启动定时器操作(TMHE1=1)时,必须设置 CMP11(即使是相同的值,也必须对 CMP11 重新设置)
  - 2. 设置 TMH1 的计数时钟频率至少是 TM51 的计数时钟频率的 6 倍。
  - 3. CMP01 和 CMP11 的值必须在 01H 和 FFH 之间。
  - 4. 定时器计数期间可以改变 CMP11 寄存器的值。但是,从改变 CMP11 的值到将该值传输到寄存器需要三个操作时钟(由 TMHMD1 寄存器的 CKS12~CKS10 位选择的时钟信号)
  - 5. 在计时操作开始前必须设置 RMC1。
- 备注: 1. 如需了解输出引脚的设置,参见 9.3 (3) 端口模式寄存器 1 (PM1)
  - 2. INTTMH1 中断信号的使用参见第二十章 中断功能。

#### 图 9-15 载波发生器模式操作时序 (1/3)

#### (a) 当 CMP01 = N, CMP11 = N 时的操作



- <1> 当 TMHE1 = 0 且 TCE51 = 0 时, 停止 8 位定时器计数器 H1 的操作。
- <2> 当 TMHE1 = 1 时,8 位定时器计数器 H1 开始计数。此时载波时钟保持默认电平状态。
- <3> 当8位定时器计数器 H1的计数值与 CMP01的值匹配时,产生第1个 INTTMH1信号并反转载波时钟信号,同时与8位定时器计数器 H1比较的比较寄存器从 CMP01切换为 CMP11。8位定时器计数器 H1的值被清零(00H)。
- <5> 当 INTTM51 信号产生时,它与 8 位定时器 H1 计数时钟同步,并作为 INTTM5H1 信号输出。
- <6> INTTM5H1 信号用作 NRZB1 位的数据传输信号,并将 NRZB1 位的值传送至 NRZ1 位。
- <7> 设置 NRZ1 = 0 时, TOH1 输出低电平。

### 图 9-15 载波发生器模式操作的时序 (2/3)

#### (b) 当 CMP01 = N, CMP11 = M 时的操作



- <1> 当 TMHE1 = 0 且 TCE51 = 0 时, 停止 8 位定时器计数器 H1 的操作。
- <2> 当 TMHE1 = 1 时,8 位定时器计数器 H1 开始计数。此时载波时钟保持默认电平状态。
- <3> 当8位定时器计数器 H1的计数值与 CMP01的值匹配时,产生第1个 INTTMH1信号并反转载波时钟信号,同时与8位定时器计数器 H1比较的比较寄存器从 CMP01切换为 CMP11。8位定时器计数器 H1的值被清零(00H)。
- <5> 当 INTTM51 信号产生时,它与 8 位定时器 H1 计数时钟同步,并作为 INTTM5H1 信号输出。
- <6> 若 NRZ1=1, 在载波时钟的第1个上升沿处输出1个载波信号。
- <7> 当 NRZ1 = 0 时,TOH1 输出保持高电平状态,在载波时钟为高电平时(在过程<6>和<7>中,保证载波时钟波形的高电平宽度)不会转变为低电平。

#### 图 9-15 载波发生器模式操作的时序 (3/3)

#### (c) 当 CMP11 改变时的操作



- <1> 当 TMHE1 = 1 时,8 位定时器 H1 开始计数。此时载波时钟保持默认电平状态。
- ★ <2> 当8位定时器计数器 H1的计数值与 CMP01的值匹配时,输出 INTTMH1信号、反转载波信号,并将定时器计数器清零(00H)。同时与8位定时器计数器 H1比较的比较寄存器从 CMP01切换为 CMP11。
- ★ <3> CMP11 与计数时钟不同步,在 8 位定时器 H1 操作期间可以修改 CMP11 的值,但修改后的新值(L)被锁存。 当 8 位定时器计数器 H1 的计数值与 CMP11 修改前的值(M)匹配(<3>')时,修改 CMP11 的值(<3>')。 但从改变 CMP11 的值到将该值传送到寄存器需要 3 个计数时钟。即使在 3 个计数时钟内产生匹配信号,新值不会被传送到寄存器
- ★ <4> 当8位定时器计数器 H1的计数值与 CMP11修改前的值(M)匹配时,输出 INTTMH1信号、反转载波信号, 并将定时器计数器清零(00H)。同时与8位定时器计数器 H1比较的比较寄存器从 CMP11切换为 CMP01。
  - <5> 由修改后的值(L)确定8位定时器计数器H1的计数值与CMP11的值再次匹配时的时序。

### 第十章 钟表定时器

## 10.1 钟表定时器的功能

钟表定时器有以下功能。

- 钟表定时器
- 间隔定时器

钟表定时器和间隔定时器可以同时使用。 图 10-1 为钟表定时器框图。

图 10-1 钟表定时器框图



**备注:** fprs: 外部硬件时钟频率

fsua:子系统时钟频率

fw: 钟表定时器时钟频率 (fprs/2<sup>7</sup> 或 fsub)

fwx: fw 或 fw/29

### (1) 钟表定时器

当使用外部硬件时钟或子系统时钟时,以预设的时间间隔产生中断请求(INTWT)。

表 10-1 钟表定时器中断时间

| 中断时间                | 操作频率 fsuв =<br>32.768 kHz | 操作频率 fprs = 2<br>MHz | 操作频率 fprs = 5<br>MHz | 操作频率 f <sub>PRS</sub> = 10<br>MHz | 操作频率 fprs = 20<br>MHz |
|---------------------|---------------------------|----------------------|----------------------|-----------------------------------|-----------------------|
| 2 <sup>4</sup> /fw  | 488 µs                    | 1.02 ms              | 410 µs               | 205 μs                            | 102 μs                |
| 2 <sup>5</sup> /fw  | 977 μs                    | 2.05 ms              | 819 µs               | 410 μs                            | 205 μs                |
| 2 <sup>13</sup> /fw | 0.25 s                    | 0.52 s               | 0.210 s              | 0.105 s                           | 52.5 ms               |
| 2 <sup>14</sup> /fw | 0.5 s                     | 1.05 s               | 0.419 s              | 0.210 s                           | 0.105 s               |

**备注:** fprs:
 外部硬件时钟频率

 fsus:
 子系统时钟频率

fw: 钟表定时器时钟频率(fprs/2<sup>7</sup>或 fsub)

#### (2) 间隔定时器

以预设的时间间隔产生中断请求(INTWTI)。

表 10-2 间隔定时器间隔时间

| 间隔时间                      | 操作频率 fsub =<br>32.768 kHz | 操作频率 f <sub>PRS</sub> = 2<br>MHz | 操作频率 f <sub>PRS</sub> = 5<br>MHz | 操作频率 fprs = 10<br>MHz | 操作频率 fprs = 20<br>MHz |
|---------------------------|---------------------------|----------------------------------|----------------------------------|-----------------------|-----------------------|
| 2 <sup>4</sup> /fw        | 488 μs 1.02 ms            |                                  | 410 μs                           | 205 μs                | 102 <i>μ</i> s        |
| 2 <sup>5</sup> /fw 977 μs |                           | 2.05 ms                          | 820 µs                           | 410 μs                | 205 μs                |
| 2 <sup>6</sup> /fw        | 1.95 ms                   | 4.10 ms                          | 1.64 ms                          | 820 μs                | 410 μs                |
| 2 <sup>7</sup> /fw        | 3.91 ms                   | 8.20 ms                          | 3.28 ms                          | 1.64 ms               | 820 µs                |
| 2 <sup>8</sup> /fw        | 7.81 ms                   | 16.4 ms                          | 6.55 ms                          | 3.28 ms               | 1.64 ms               |
| 2 <sup>9</sup> /fw        | 15.6 ms                   | 32.8 ms                          | 13.1 ms                          | 6.55 ms               | 3.28 ms               |
| 2 <sup>10</sup> /fw       | 31.3 ms                   | 65.5 ms                          | 26.2 ms                          | 13.1 ms               | 6.55 ms               |
| 2 <sup>11</sup> /fw       | 62.5 ms                   | 131.1 ms                         | 52.4 ms                          | 26.2 ms               | 13.1 ms               |

**备注:** fprs: 外部硬件时钟频率

fsua: 子系统时钟频率

fw: 钟表定时器时钟频率 (fprs/2<sup>7</sup>或 fsub)

# 10.2 钟表定时器的配置

钟表定时器包括以下硬件。

表 10-3 钟表定时器的配置

|       | た。 で パルル           |
|-------|--------------------|
| 项目    | 配置                 |
| 计数器   | 5位×1               |
| 预分频器  | 11位×1              |
| 控制寄存器 | 钟表定时器操作模式寄存器 (WTM) |

### 10.3 控制钟表定时器的寄存器

由钟表定时器操作模式寄存器(WTM)控制钟表定时器。

### • 钟表定时器操作模式寄存器(WTM)

该寄存器用于设置钟表定时器计数时钟、允许/禁止操作、预分频器间隔时间和 5 位计数器操作控制。可以由 1 位或 8 位存储器操作指令设置 WTM。 复位信号的产生将 WTM 清零(00H)。

#### 图 10-2 钟表定时器操作模式寄存器 (WTM) 的格式

 地址: FF6FH 复位后: 00H R/W

 符号
 7
 6
 5
 4
 3
 2
 <1> <0>

WTM WTM7 WTM6 WTM5 WTM4 WTM3 WTM2 WTM1 WTM0

| WTM7 |                     | 钟表定时器计数时钟选择 <b>(fw)</b> |              |              |               |               |  |
|------|---------------------|-------------------------|--------------|--------------|---------------|---------------|--|
|      |                     | fsuB = 32.768 kHz       | fprs = 2 MHz | fprs = 5 MHz | fprs = 10 MHz | fprs = 20 MHz |  |
| 0    | fprs/2 <sup>7</sup> | _                       | 15.625 kHz   | 39.062 kHz   | 78.125 kHz    | 156.25 kHz    |  |
| 1    | fsuB                | 32.768 kHz              | -            |              |               |               |  |

| WTM6 | WTM5 | WTM4 | 预分频器间隔时间选择          |
|------|------|------|---------------------|
| 0    | 0    | 0    | 2 <sup>4</sup> /fw  |
| 0    | 0    | 1    | 2⁵/fw               |
| 0    | 1    | 0    | 2 <sup>6</sup> /fw  |
| 0    | 1    | 1    | 2 <sup>7</sup> /fw  |
| 1    | 0    | 0    | 2 <sup>8</sup> /fw  |
| 1    | 0    | 1    | 2 <sup>9</sup> /fw  |
| 1    | 1    | 0    | 2 <sup>10</sup> /fw |
| 1    | 1    | 1    | 2 <sup>11</sup> /fw |

| WTM3 | WTM2 | 钟表定时器中断时间选择         |
|------|------|---------------------|
| 0    | 0    | 2 <sup>14</sup> /fw |
| 0    | 1    | 2 <sup>13</sup> /fw |
| 1    | 0    | 2⁵/fw               |
| 1    | 1    | 2 <sup>4</sup> /fw  |

| WTM1 | 5 位计数器操作控制 |  |  |  |  |
|------|------------|--|--|--|--|
| 0    | 操作停止后清零    |  |  |  |  |
| 1    | 启动操作       |  |  |  |  |

| WTM0                 | 钟表定时器操作允许 |  |  |  |  |
|----------------------|-----------|--|--|--|--|
| 0 停止操作(预分频器和5位计数器清零) |           |  |  |  |  |
| 1                    | 允许操作      |  |  |  |  |

注意事项: 在钟表定时器操作期间不要修改计数时钟和间隔时间 (通过设置 WTM 的第  $4\sim7$  位 (WTM $4\sim$  WTM7) 实现)。

**备注:** 1. fw: 钟表定时器时钟频率(fx/2<sup>7</sup> 或 fxT)

fprs: 外部硬件时钟频率
 fsub: 子系统时钟频率

#### 10.4 钟表定时器操作

### 10.4.1 钟表定时器操作

通过使用外部硬件时钟或子系统时钟,钟表定时器以指定的时间间隔产生中断请求(INTWT)。

当钟表定时器操作模式寄存器(WTM)的第 0 位(WTM0)和第 1 位(WTM1)为 1 时,开始计数操作。当这些位被设置为零时,将 5 位计数器清零,同时停止计数操作。

在间隔定时器操作的同时,通过将 WTM1 清零,钟表定时器的零秒启动被激活。但在这种情况中,不对 11 位预分频器清零。因此,在零秒启动后的第 1 次溢出(INTWT)时会产生  $1 ext{ } ext{$ 

按以下时间间隔产生中断请求。

表 10-4 钟表定时器中断时间

| WTM3 | WTM2 | 中断时间选择              | 操作频率 fsua = | 操作频率 fprs = 2  | 操作频率 fprs = 5  | 操作频率 fprs = 10 | 操作频率 fprs = 20 |
|------|------|---------------------|-------------|----------------|----------------|----------------|----------------|
|      |      |                     | 32.768 kHz  | MHz (WTM7 = 0) |
|      |      |                     | (WTM7 = 1)  |                |                |                |                |
| 0    | 0    | 2 <sup>14</sup> /fw | 0.5 s       | 1.05 s         | 0.419 s        | 0.210 s        | 0.105 s        |
| 0    | 1    | 2 <sup>13</sup> /fw | 0.25 s      | 0.52 s         | 0.210 s        | 0.105 s        | 52.5 ms        |
| 1    | 0    | 2 <sup>5</sup> /fw  | 977 μs      | 2.05 ms        | 819 <i>μ</i> s | 410 <i>μ</i> s | 205 μs         |
| 1    | 1    | 2 <sup>4</sup> /fw  | 488 μs      | 1.02 ms        | 410 <i>μ</i> s | 205 μs         | 102 <i>μ</i> s |

**备注: 1.** fw: 钟表定时器时钟频率(fprs/2<sup>7</sup> 或 fsub)

**2.** fprs: 外部硬件时钟频率 **3.** fsub: 子系统时钟频率

## 10.4.2 间隔定时器操作

钟表定时器用作间隔定时器时,以预设的时间间隔重复产生中断请求(INTWTI)。

可以由钟表定时器操作模式寄存器(WTM)的第 4~6 位(WTM4 ~ WTM6)选择间隔时间。

当 WTM 的第 0 位(WTM0)为 1 时,开始计数。而当该位被设置为零时,停止计数。

表 10-5 间隔定时器间隔时间

| WTM6 | WTM5 | WTM4 | 间隔时间                | 操作频率 fsuB =    | 操作频率 fprs =   | 操作频率 fprs =    | 操作频率 fprs =    | 操作频率 fprs =    |
|------|------|------|---------------------|----------------|---------------|----------------|----------------|----------------|
|      |      |      |                     | 32.768 kHz     | 2 MHz (WTM7 = | 5 MHz (WTM7 =  | 10 MHz (WTM7   | 20 MHz (WTM7   |
|      |      |      |                     | (WTM7 = 1)     | 0)            | 0)             | = 0)           | = 0)           |
| 0    | 0    | 0    | 2 <sup>4</sup> /fw  | 488 μs         | 1.02 ms       | 410 <i>μ</i> s | 205 μs         | 102 <i>μ</i> s |
| 0    | 0    | 1    | 2 <sup>5</sup> /fw  | 977 <i>μ</i> s | 2.05 ms       | 820 <i>μ</i> s | 410 <i>μ</i> s | 205 μs         |
| 0    | 1    | 0    | 2 <sup>6</sup> /fw  | 1.95 ms        | 4.10 ms       | 1.64 ms        | 820 <i>µ</i> s | 410 <i>μ</i> s |
| 0    | 1    | 1    | 2 <sup>7</sup> /fw  | 3.91 ms        | 8.20 ms       | 3.28 ms        | 1.64 ms        | 820 <i>μ</i> s |
| 1    | 0    | 0    | 2 <sup>8</sup> /fw  | 7.81 ms        | 16.4 ms       | 6.55 ms        | 3.28 ms        | 1.64 ms        |
| 1    | 0    | 1    | 2 <sup>9</sup> /fw  | 15.6 ms        | 32.8 ms       | 13.1 ms        | 6.55 ms        | 3.28 ms        |
| 1    | 1    | 0    | 2 <sup>10</sup> /fw | 31.3 ms        | 65.5 ms       | 26.2 ms        | 13.1 ms        | 6.55 ms        |
| 1    | 1    | 1    | 2 <sup>11</sup> /fw | 62.5 ms        | 131.1 ms      | 52.4 ms        | 26.2 ms        | 13.1 ms        |

**备注:** 1. fw: 钟表定时器时钟频率(fprs/2<sup>7</sup> 或 fsub)

**2.** fprs: 外部硬件时钟频率 **3.** fsub: 子系统时钟频率

 5 位计数器

 OH

 Ia动

 A

 Ia动

 P#表定时器

 中断 INTWT

 中表定时器

 中断 INTWTI

 III

 III

图 10-3 钟表定时器/间隔定时器的操作时序

**备注:** fw: 钟表定时器时钟频率

图中括号里的值为 fw = 32.768 kHz (WTM7 = 1, WTM3, WTM2 = 0, 0) 时的操作结果

## 10.5 钟表定时器使用注意事项

通过钟表定时器模式控制寄存器(WTM)(WTM 的第 0 位(WTM0)和第 1 位(WTM1)置 1)允许钟表定时器和 5 位计数器操作时,从寄存器被设置后到第 1 个中断请求(INTWT)产生的这段间隔时间与 WTM 的第 2 和 3 位(WTM2 和 WTM3)指定的间隔时间并不完全匹配。但其后的 INTWT 信号会以指定的时间间隔产生。

### 图 10-4 钟表定时器中断请求 (INTWT) 产生示例 (当中断周期 = 0.5 s)

经过 0.515625 秒产生第 1 个 INTWT( $2^9 \times 1/32768 = 0.015625 s$ )。 随后 INTWT 每 0.5 秒产生 1 次。



### 第十一章 看门狗定时器

### 11.1 看门狗定时器的功能

看门狗定时器使用内部低速振荡时钟。

看门狗定时器用于检测不期望出现的程序循环。如果检测到一个程序循环,将产生一个内部复位信号。 出现以下情况时检测程序循环。

- 如果看门狗定时器计数器溢出
- 如果对看门狗定时器使能寄存器(WDTE)执行 1 位操作指令。
- 如果将"ACH"以外的数据写入 WDTE
- 如果在窗口关闭期间将数据写入 WDTE
- 如果从没有通过 IMS 和 IXS 寄存器设置的区域获取指令(在 CPU 挂起时检查是否有无效校验)
- 如果因为执行 1条读/写指令, CPU 访问了没有通过 IMS 和 IXS 寄存器设置的区域(FB00H ~ FFFFH 除外) (CPU 程序循环期间检测是否有非法访问)

当由看门狗定时器产生复位时,复位控制标志寄存器(RESF)的第 4 位(WDTRF)置 1。需要了解 RESF 的详细信息,可以参阅**第二十三章 复位功能**。

### 11.2 看门狗定时器的配置

看门狗定时器包含以下硬件。

表 11-1 看门狗定时器的配置

| 项目    | 配置                 |  |
|-------|--------------------|--|
| 控制寄存器 | 看门狗定时器使能寄存器 (WDTE) |  |

由选项字节设置如何控制计数器的操作、溢出时间和窗口打开周期。

表 11-2 选项字节和看门狗定时器的设置

| 看门狗定时器的设置      | 选项字节 (0080H)              |  |  |
|----------------|---------------------------|--|--|
| 窗口打开周期         | 第6位和第5位(WINDOW1, WINDOW0) |  |  |
| 控制看门狗定时器的计数器操作 | 第4位 (WDTON)               |  |  |
| 看门狗定时器的溢出时间    | 第3位~第1位(WDCS2~WDCS0)      |  |  |

**备注:** 需要了解选项字节的内容,可参见**第二十六章 选项字节**。

图 11-1 看门狗定时器的框图



### 11.3 控制看门狗定时器的寄存器

看门狗定时器由看门狗定时器使能寄存器(WDTE)控制。

## (1) 看门狗定时器使能寄存器(WDTE)

将 ACH 写入 WDTE 可以对看门狗定时器计数器清零并再次开始计数操作。可以由 8 位存储器操作指令设置该寄存器。 复位信号的产生将该寄存器设置为 9AH 或 1AH <sup>24</sup>。

### 图 11-2 看门狗定时器使能寄存器 (WDTE)的格式

| 地址:「 | FF99H | 复位后: 9AH | I/1AH <sup>注</sup> R | /W |   |   |   |   |
|------|-------|----------|----------------------|----|---|---|---|---|
| 符号   | 7     | 6        | 5                    | 4  | 3 | 2 | 1 | 0 |
| WDTE |       |          |                      |    |   |   |   |   |

**注:** WDTE 的复位值随选项字节(0080H)的 WDTON 位的设置值而变化。 如果要对看门狗定时器进行操作,设置 WDTON = 1。

| WDTON设置值           | WDTE复位值 |
|--------------------|---------|
| 0 (禁止看门狗定时器计数器的操作) | 1AH     |
| 1 (允许看门狗定时器计数器的操作) | 9AH     |

- 注意事项: 1. 如果写入 WDTE 的值不是 ACH,将产生一个内部复位信号。如果看门狗定时器的时钟源被停止,则当看门狗定时器的时钟源恢复操作时,将产生内部复位信号。
  - 2. 如果使用 1 位存储器操作指令对 WDTE 进行操作,将产生一个内部复位信号。如果看门狗定时器的时钟源被停止,当提供给看门狗定时器的时钟源恢复操作时,将产生内部复位信号。
  - 3. 从 WDTE 读取的值为 9AH/1AH(与写入值(ACH)不同)。

#### 11.4 看门狗定时器操作

#### 11.4.1 看门狗定时器操作的控制

- 1. 当使用看门狗定时器时,由选项字节(0080H)指定其操作。
  - 通过设置选项字节(0080H)的第 4 位(WDTON)=1,允许看门狗定时器的计数操作(复位释放后计数器开始计数)(如需了解详细信息,可参见**第二十六章**)。

| WDTON | 看门狗定时器计数器的操作控制/非法访问检测          |  |  |  |  |  |  |
|-------|--------------------------------|--|--|--|--|--|--|
| 0     | 禁止计数器操作 (复位后停止计数),禁止非法访问检测操作   |  |  |  |  |  |  |
| 1     | 允许计数器操作 (复位后开始计数),允许进行非法访问检测操作 |  |  |  |  |  |  |

- 通过使用选项字节(0080H)的第 3 位~第 1 位(WDCS2 ~ WDCS0)设置溢出时间(如需了解详细信息,参见 11.4.2 和第二十六章)。
- 通过使用选项字节(0080H)的第 6 位和第 5 位(WINDOW1 和 WINDOW0)设置窗口打开周期(如需了解详细信息,参见 11.4.3 和第二十六章)。
- 2. 复位释放后, 看门狗定时器开始计数。
- 3. 在看门狗定时器开始计数后且在达到选项字节设置的溢出时间之前,将"ACH"写入 WDTE,看门狗定时器将被清零并再次开始计数。
- 4. 经过上述步骤后对 WDTE 进行第二次写操作,或在复位释放后的窗口打开期间对 WDTE 进行第二次写操作。如果在窗口关闭期间对 WDTE 进行写操作,则会产生内部复位信号。
- 5. 如果已经历了溢出时间还没有将"ACH"写入 WDTE,则会产生内部复位信号。
- ★ 出现以下情况时会产生内部复位信号。
  - 如果对看门狗定时器使能寄存器(WDTE)执行位操作指令时。
  - 如果将"ACH"以外的数据写入 WDTE。
  - 如果从没有通过 IMS 和 IXS 寄存器设置的区域获取指令(在 CPU 程序循环期间检查是否有无效校验)
  - 如果因为执行 1 条读/写指令, CPU 访问了没有通过 IMS 和 IXS 寄存器设置的区域(FB00H ~ FFFFH 除外) (CPU 程序循环期间检测是否有非法访问)
  - 注意事项: 1. 复位释放后对 WDTE 进行第一次写操作,将清零看门狗定时器,如果这一操作是在到达溢出时间之前进行的而不管写操作时序,看门狗定时器再次开始计数。
    - 2. 如果通过将"ACH"写入 WDTE 来对看门狗定时器清零,则实际的溢出时间可能与由选项字节设置的 溢出时间不同,最高可达 2/f<sub>RL</sub> 秒。
    - 3. 在计数值溢出(FFFFH)之前,可将看门狗定时器立即清零。

注意事项: 4. 在 HALT 和 STOP 模式下看门狗定时器的操作依据选项字节第 0 位(LSROSC)的设置值的不同而不同,如下所示。

|         | LSROSC = 0 (可由软件停止内部低速振荡器) | LSROSC = 1 (不能停止內部低速振荡器) |
|---------|----------------------------|--------------------------|
| HALT 模式 | 看门狗定时器操作停止                 | 看门狗定时器操作继续               |
| STOP 模式 |                            |                          |

如果 LSROSC = 0,则在 HALT 或 STOP 模式释放后看门狗定时器恢复计数。此时,不对计数器清零,而从计数器停止时的值开始计数。

如果在 LSROSC = 0 时通过设置 LSRSTOP(内部振荡模式寄存器(RCM)的第 1 位=1)停止内部低速振荡器的振荡,则看门狗定时器停止操作。此时不对计数器清零(0)。

5. 在闪存自编程和 EEPROM<sup>™</sup> 仿真期间看门狗定时器不停止操作。在处理期间中断响应被延迟。设置 溢出时间和窗口大小时,应考虑延迟。

#### 11.4.2 看门狗定时器溢出时间的设置

通过使用选项字节(0080H)的第3位~第1位(WDCS2~WDCS0),设置看门狗定时器的溢出时间。

如果出现溢出,则将产生内部复位信号。在到达溢出时间之前且在窗口打开周期内通过将"ACH"写入 WDTE,可对当前计数值清零,且看门狗定时器再次开始计数。

溢出时间设置如下所示。

WDCS2 WDCS1 WDCS0 看门狗定时器的溢出时间 0 0 0 2<sup>10</sup>/f<sub>RL</sub> (3.88 ms)  $2^{11}/f_{RL}$  (7.76 ms) 0 0 1 2<sup>12</sup>/f<sub>RL</sub> (15.52 ms) 0 0 1 2<sup>13</sup>/f<sub>RL</sub> (31.03 ms) 0 1 1 2<sup>14</sup>/f<sub>RL</sub> (62.06 ms) 1 0 0 1 0 1 2<sup>15</sup>/f<sub>RL</sub> (124.12 ms) 2<sup>16</sup>/f<sub>RL</sub> (248.24 ms) 1 1 0 2<sup>17</sup>/f<sub>RL</sub> (496.48 ms) 1 1 1

表 11-3 看门狗定时器溢出时间的设置

注意事项: 1. 禁止出现 WDCS2 = WDCS1 = WDCS0 = 0 且 WINDOW1 = WINDOW0 = 0 的情况。

2. 在闪存自编程和 EEPROM 仿真期间看门狗定时器不停止操作。在处理期间中断响应被延迟。设置溢出时间和窗口大小时,应考虑延迟。

**备注:** 1. fr.L: 内部低速振荡时钟频率

**2.** ( ): frL = 264 kHz (MAX.)

#### 11.4.3 看门狗定时器窗口打开周期的设置

通过使用选项字节(0080H)的第 6 位和第 5 位(WINDOW1, WINDOW0),设置看门狗定时器的窗口打开周期。窗口使用情况描述如下。

- 如果在窗口打开期间将"ACH"写入 WDTE,则对看门狗定时器清零并再次开始计数。
- 即使在窗口关闭期间即使将"ACH"写入 WDTE, 也会检测到异常情况, 并产生内部复位信号。

举例: 如果窗口打开周期为 25%



注意事项: 复位释放后对 **WDTE** 进行第一次写操作,将清零看门狗定时器,如果这一操作是在到达溢出时间之前进行的而不管写操作时序,看门狗定时器再次开始计数。

窗口打开周期设置如下所示。

 WINDOW1
 WINDOW0
 看门狗定时器的窗口打开周期

 0
 0
 25%

 0
 1
 50%

 1
 0
 75%

 1
 1
 100%

表 11-4 看门狗定时器窗口打开周期的设置

注意事项: 1. 禁止出现 WDCS2 = WDCS1 = WDCS0 = 0 且 WINDOW1 = WINDOW0 = 0 的情况。

2. 在闪存自编程和 EEPROM 仿真期间看门狗定时器不停止操作。在处理阶段中断响应被延迟。设置溢出时间和窗口大小时,应考虑延迟。

**备注:** 如果将溢出时间设置为 2<sup>10</sup>/fRL,则窗口关闭时间和打开时间如下所示。

|        |                          | 窗口打开周期的设置                 |                             |                        |  |  |
|--------|--------------------------|---------------------------|-----------------------------|------------------------|--|--|
|        | 25%                      | 50%                       | 75%                         | 100%                   |  |  |
| 窗口关闭时间 | $0 \sim 3.56 \text{ ms}$ | $0\sim$ 2.37 ms           | $0\sim$ 0.119 ms            | 无                      |  |  |
| 窗口打开时间 | $3.56\sim3.88~\text{ms}$ | $\rm 2.37 \sim 3.88 \ ms$ | $0.119 \sim 3.88~\text{ms}$ | $0\sim 3.88~\text{ms}$ |  |  |

### <当窗口打开周期为 25%>

• 溢出时间:

$$2^{10}/f_{RL}$$
 (MAX.) =  $2^{10}/264$  kHz (MAX.) = 3.88 ms

• 窗口关闭时间:

$$0\sim2^{10}\!/\!\text{fRL}$$
 (MIN.)  $\times$  (1  $-$  0.25) = 0  $\sim2^{10}\!/\!216$  kHz (MIN.)  $\times$  0.75 = 0  $\sim$  3.56 ms

• 窗口打开时间:

$$2^{10}\!/\!f_{RL}$$
 (MIN.)  $\times$  (1  $-$  0.25)  $\sim$   $2^{10}\!/\!f_{RL}$  (MAX.) =  $2^{10}\!/\!216$  kHz (MIN.)  $\times$  0.75  $\sim$   $2^{10}\!/\!264$  kHz (MAX.)

= 3.56  $\sim$  3.88 ms

## 第十二章 时钟输出/蜂鸣器输出控制器

## 12.1 时钟输出/蜂鸣器输出控制器的功能

时钟输出控制器用于遥控发射期间的载波输出,以及用于外部 IC 的时钟输出。可以输出由时钟输出选择寄存器 (CKS) 选择的时钟。

此外蜂鸣器输出用于由CKS选择的蜂鸣器频率的方波输出。

图 12-1 显示了时钟输出/蜂鸣器输出控制器的框图。

图 12-1 时钟输出/蜂鸣器输出控制器的框图



### 12.2 时钟输出/蜂鸣器输出控制器的配置

时钟输出/蜂鸣器输出控制器包括以下硬件。

表 12-1 时钟输出/蜂鸣器输出控制器的配置

| 项目    | 配置                                                     |  |  |  |  |
|-------|--------------------------------------------------------|--|--|--|--|
| 控制寄存器 | 时钟输出选择寄存器 (CKS)<br>端口模式寄存器 14 (PM14)<br>端口寄存器 14 (P14) |  |  |  |  |

# 12.3 控制时钟输出/蜂鸣器输出控制器的寄存器

以下两个寄存器用于控制时钟输出/蜂鸣器输出控制器。

- 时钟输出选择寄存器 (CKS)
- 端口模式寄存器 14 (PM14)

## (1) 时钟输出选择寄存器(CKS)

该寄存器用于设置时钟输出(PCL)和蜂鸣器频率输出(BUZ)的输出允许/禁止,并设置输出时钟。可以由 1 位或 8 位存储器操作指令设置 CKS。

复位信号的产生将 CKS 清零(00H)。

### 图 12-2 时钟输出选择寄存器 (CKS) 的格式

地址: FF40H 复位后: 00H R/W

符号

CKS

| <7>  | 6    | 5    | <4>  | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| BZOE | BCS1 | BCS0 | CLOE | CCS3 | CCS2 | CCS1 | CCS0 |

| BZOE | BUZ 输出允许/禁止           |  |  |  |  |  |
|------|-----------------------|--|--|--|--|--|
| 0    | 停止时钟分频电路的操作。BUZ恒为低电平。 |  |  |  |  |  |
| 1    | 允许时钟分频电路的操作。BUZ输出允许。  |  |  |  |  |  |

| BCS1 | BCS0 | BUZ 输出时钟选择           |               |               |  |  |
|------|------|----------------------|---------------|---------------|--|--|
|      |      |                      | fprs = 10 MHz | fprs = 20 MHz |  |  |
| 0    | 0    | fprs/2 <sup>10</sup> | 9.77 kHz      | 19.54 kHz     |  |  |
| 0    | 1    | fprs/2 <sup>11</sup> | 4.88 kHz      | 9.77 kHz      |  |  |
| 1    | 0    | fprs/2 <sup>12</sup> | 2.44 kHz      | 4.88 kHz      |  |  |
| 1    | 1    | fprs/2 <sup>13</sup> | 1.22 kHz      | 2.44 kHz      |  |  |

| CLOE | PCL 输出允许/禁止            |  |  |  |  |  |
|------|------------------------|--|--|--|--|--|
| 0    | 停止时钟分频电路的操作。PCL 恒为低电平。 |  |  |  |  |  |
| 1    | 允许时钟分频电路的操作。PCL 输出允许。  |  |  |  |  |  |

| CCS3 | CCS2 | CCS1 | CCS0 | PCL 输出时钟选择                       |            |            |            |
|------|------|------|------|----------------------------------|------------|------------|------------|
|      |      |      |      |                                  | fsub =     | fprs =     | fprs =     |
|      |      |      |      |                                  | 32.768 kHz | 10 MHz     | 20 MHz     |
| 0    | 0    | 0    | 0    | fprs # 1                         | -          | 10 MHz     | 禁止设置 2     |
| 0    | 0    | 0    | 1    | fprs/2                           |            | 5 MHz      | 10 MHz     |
| 0    | 0    | 1    | 0    | fprs/2 <sup>2</sup>              |            | 2.5 MHz    | 5 MHz      |
| 0    | 0    | 1    | 1    | fprs/2 <sup>3</sup>              |            | 1.25 MHz   | 2.5 MHz    |
| 0    | 1    | 0    | 0    | fprs/24                          |            | 625 kHz    | 1.25 MHz   |
| 0    | 1    | 0    | 1    | fprs/2 <sup>5</sup>              |            | 312.5 kHz  | 625 kHz    |
| 0    | 1    | 1    | 0    | f <sub>PRS</sub> /2 <sup>6</sup> |            | 156.25 kHz | 312.5 kHz  |
| 0    | 1    | 1    | 1    | fprs/2 <sup>7</sup>              |            | 78.125 kHz | 156.25 kHz |
| 1    | 0    | 0    | 0    | fsuв                             | 32.768 kHz | -          | =          |
| 其它情况 |      |      |      | 禁止设置                             |            |            |            |

- ★ 注: 1. 当 1.8 V ≤ VDD < 2.7 V 时,如果外部硬件时钟使用内部高速振荡时钟操作时,禁止设置 CCS3 = CCS2 = CCS1 = CCS0 = 0 (PCL 的输出时钟: fprs)。</li>
  - 2. 禁止设置超过 10 MHz 的 PCL 输出时钟频率。
- ★ 注意事项: 1. 当蜂鸣器输出操作停止时(BZOE = 0),设置 BCS1 和 BCS0。
- ★ 2. 当时钟输出操作停止时(CLOE = 0),设置 CCS3 ~ CCS0。

**备注: 1. f**PRS: 外部硬件时钟频率

2. fsua: 子系统时钟频率

# (2) 端口模式寄存器 14 (PM14)

该寄存器可位选端口14的输入/输出操作模式。

当使用 P140/INTP6/PCL 引脚作为时钟输出和使用 P141/BUSY0/INTP7/BUZ 引脚作为蜂鸣器输出时,设置 PM140、PM141 和 P140 与 P141 的输出锁存器的值为 0。

可以由1位或8位存储器操作指令设置PM14。

复位信号产生将 PM14 设置为 FFH。

图 12-3 端口模式寄存器 14 (PM14) 的格式

 地址:
 FF2EH
 复位后:
 FFH
 R/W

 符号
 7
 6
 5
 4
 3
 2
 1
 0

 PM14
 1
 1
 PM145
 PM144
 PM143
 PM142
 PM141
 PM140

| PM14n | P14n 引脚 I/O 模式选择 (n = 0~5) |
|-------|----------------------------|
| 0     | 输出模式 (输出缓冲器打开)             |
| 1     | 输入模式 (输出缓冲器关闭)             |

#### 12.4 时钟输出/蜂鸣器输出控制器的操作

#### 12.4.1 时钟输出操作

时钟脉冲输出包含以下过程。

- <1> 通过时钟输出选择寄存器(CKS)的第0位~第3位(CCS0~CCS3)选择时钟脉冲输出频率(时钟脉冲输出 为禁止状态)。
- <2> 将 CKS 的第 4 位 (CLOE) 置 1, 允许时钟输出。

**备注:** 在时钟输出的输出允许/禁止切换阶段,时钟输出控制器不能输出小宽度的脉冲。如图 12-4 所示,必须确保在时钟的低电平区(图中标\*处)启动输出。当停止输出时,也必须在时钟高电平之后停止输出。

图 12-4 遥控输出应用举例

## 12.4.2 蜂鸣器输出操作

蜂鸣器频率输出包含以下过程。

- <1> 通过时钟输出选择寄存器(CKS)的第5位和第6位(BCS0、BCS1)选择蜂鸣器输出频率(蜂鸣器输出为禁止状态)。
- <2> 将 CKS 的第 7 位 (BZOE) 置 1, 允许蜂鸣器输出。

# 第十三章 A/D 转换器

# 13.1 A/D 转换器的功能

A/D 转换器用于将模拟输入信号转换为数字信号,最多可由 8 个通道(ANI0  $\sim$  ANI7)组成,具有 10 位分辨率。 A/D 转换器有以下功能。

#### • 10 位分辨率 A/D 转换

从模拟输入 ANIO~ANI7 中选择一个通道,重复执行 10 位分辨率 A/D 转换。每次 A/D 转换结束,都可以产生一个中断请求(INTAD)。



# 13.2 A/D 转换器的配置

A/D转换器包括以下硬件。

#### (1) ANI0 ~ ANI7 引脚

这些是 8 通道 A/D 转换器的模拟输入引脚。用于输入模拟信号,以便转换成数字信号。除了那些被选为模拟输入的引脚外,其它引脚均可用作 I/O 端口引脚。

# (2) 采样&保持电路

采样&保持电路在 A/D 转换器启动时用于采样由选择器选择的模拟输入引脚的输入电压,并在 A/D 转换期间保持采样到的电压值。

#### (3) 串联电阻串

串联电阻串用于连接 AVREF 和 AVSS,并产生一个电压,与采样到的电压值进行比较。

#### 图 13-2 串联电阻串的电路配置



## (4) 电压比较器

电压比较器用于比较采样到的电压值与串联电阻串的输出电压。

## (5) 逐次逼近寄存器 (SAR)

★ 该寄存器用于转换电压比较器所比较的结果,并从最高有效位(MSB)开始转换结果。 当电压被转换成数字值,并写入最低有效位时(A/D 转换结束),将 SAR 的内容传送到 A/D 转换结果寄存器(ADCR)中。

#### (6) 10 位 A/D 转换结果寄存器 (ADCR)

每次 A/D 转换结束时,将 A/D 转换结果从逐次逼近寄存器(SAR)传送至该寄存器中。并由该寄存器将转换结果保存在它的高 10 位中(低 6 位恒为 0)。

# (7) 8 位 A/D 转换结果寄存器 (ADCRH)

每次 A/D 转换结束时,将 A/D 转换结果从逐次逼近寄存器传送至该寄存器中。并将转换结果保存在 ADCRH 的高 8 位中。

注意事项: 当从 ADCR 和 ADCRH 读取数据时,会产生一个等待周期。当 CPU 工作在子系统时钟,且外部硬件时钟处于停止状态时,不要从 ADCR 和 ADCRH 读取数据。需要了解详细信息,可参阅第三十二章等待注意事项。

#### (8) 控制器

该电路用于控制模拟输入信号被转换成数字信号的转换时间,并启动和停止转换操作。当 A/D 转换结束时,该控制器产生中断 INTAD。

#### (9) AVREF 引脚

★ 该引脚为 A/D 转换器输入一个模拟供电/参考电压。当端口 2 被用作数字端口时,该引脚的电压应与 Vpb 的电压保持一致。

根据 AVREF 和 AVSS 的电压,将输入到 ANIO ~ ANI7 的信号转换成数字信号。

## (10) AVss 引脚

这是 A/D 转换器的信号地引脚。即便没有使用 A/D 转换器,该引脚的电压也应与 Vss 的电压保持一致。

## (11) A/D 转换器模式寄存器(ADM)

该寄存器用于设置被转换的模拟输入信号的转换时间,并启动或停止转换操作。

#### (12) A/D 端口配置寄存器(ADPC)

该寄存器用于将 ANIO/P20 ~ANI7/P27 引脚切换成 A/D 转换器的模拟输入或端口的数字 I/O。

# (13) 模拟输入通道选择寄存器 (ADS)

该寄存器用来选择输入模拟电压(将被转换成数字信号)的端口。

#### (14) 端口模式寄存器 2 (PM2)

该寄存器用于将 ANIO/P20 ~ANI7/P27 引脚切换为输入或输出。

# 13.3 A/D 转换器使用的寄存器

A/D 转换器使用以下六个寄存器。

- A/D 转换器模式寄存器 (ADM)
- A/D 端口配置寄存器(ADPC)
- 模拟输入通道选择寄存器 (ADS)
- 端口模式寄存器 2 (PM2)
- 10 位 A/D 转换结果寄存器(ADCR)
- 8 位 A/D 转换结果寄存器(ADCRH)

## (1) A/D 转换器模式寄存器 (ADM)

该寄存器设置模拟输入的 A/D 转换时间,并启动/停止转换。

可由 1 位或 8 位存储器操作指令设置 ADM。

复位信号产生将该寄存器清零(00H)。

# 图 13-3 A/D 转换器模式寄存器 (ADM)的格式

| 地址: | FF28H | 复位后: 0 | 0H R/W              |                   |                   |                    |                   |      |
|-----|-------|--------|---------------------|-------------------|-------------------|--------------------|-------------------|------|
| 符号  | <7>   | 6      | 5                   | 4                 | 3                 | 2                  | 1                 | <0>  |
| ADM | ADCS  | 0      | FR2 <sup>l 注1</sup> | FR1 <sup>注1</sup> | FR0 <sup>推1</sup> | LV1 <sup>注 1</sup> | LV0 <sup>注1</sup> | ADCE |

| ADCS | A/D 转换操作控制 |
|------|------------|
| 0    | 停止转换操作     |
| 1    | 允许转换操作     |

| ADCE | 比较器操作控制 <sup><b>性2</b></sup> |
|------|------------------------------|
| 0    | 停止比较器的操作                     |
| 1    | 允许比较器的操作 (比较器: 1/2AVREF操作)   |

- 注: 1. 如需了解 FR2~FR0、LV1、LV0 和 A/D 转换的详细信息,可参见表 13-2 A/D 转换时间的选择。
  - 2. 比较器的的操作是由 ADCS 和 ADCE 控制的,从操作开始到操作稳定需要 1μs。因此,当 ADCE 被设置为 1 后,至少经过 1μs 的时间,再将 ADCS 置 1 时,此时的转换结果优先与第一次的转换结果。否则,忽略第一次转换的数据。

表 13-1 ADCS 和 ADCE 的设置

| ADCS | ADCE | A/D 转换操作                          |  |  |  |  |  |  |
|------|------|-----------------------------------|--|--|--|--|--|--|
| 0    | 0    | 停止状态 (不存在直流功耗)                    |  |  |  |  |  |  |
| 0    | 1    | 换等待模式 (比较器: 1/2AVREF操作,只有比较器产生功耗) |  |  |  |  |  |  |
| 1    | 0    | 转换模式 (停止比较器的操作 <sup>*</sup> )     |  |  |  |  |  |  |
| 1    | 1    | 转换模式 (比较器: 1/2AVREF操作)            |  |  |  |  |  |  |

注: 因为第一次转换的结果不确定,因此忽略第1次转换的数据。

图 13-4 使用参考电压发生器时的时序图



- 注: 从 ADCE 位上升到 ADCS 位下降所需时间必须至少为 1 μs, 以便稳定内部电路。
- 注意事项: 1. 在将 FR0  $\sim$  FR2 位, LV1 和 LV0 位修改成其他值之前, A/D 转换必须停止。
  - 2. 如果对 ADM 赋值,会产生 1 个等待周期。当 CPU 工作在子系统时钟,且外部硬件时钟处于停止状态时,不要对 ADM 赋值。需要了解详细信息,可参阅第三十二章 等待注意事项。

# 表 13-2 A/D 转换时间的选择

#### (1) $2.7 \text{ V} \leq \text{AV}_{\text{REF}} \leq 5.5 \text{ V}$

| A/I | A/D 转换器模式寄存器(ADM) |     |     |     |                      | 转换时             | 间的选择                        |                              | 转换时钟                 |                   | 转换日               | 寸间配置               |                          |
|-----|-------------------|-----|-----|-----|----------------------|-----------------|-----------------------------|------------------------------|----------------------|-------------------|-------------------|--------------------|--------------------------|
| FR2 | FR1               | FR0 | LV1 | LV0 |                      | fprs =<br>2 MHz | fprs =<br>10 MHz            | fprs = 20 MHz **             | (fad)                | SAR 清<br>零        | 采样                | 逐次转换时<br>间         | ADCR 传<br>送, INTAD<br>产生 |
| 0   | 0                 | 0   | 0   | 0   | 264/f <sub>PRS</sub> | 禁止设置            | 26.4 μs                     | 13.2 <i>μ</i> s <sup>≇</sup> | f <sub>PRS</sub> /12 | 2/f <sub>AD</sub> | 6/f <sub>AD</sub> | 12/f <sub>AD</sub> | 2/f <sub>AD</sub>        |
| 0   | 0                 | 1   | 0   | 0   | 176/fprs             |                 | 17.6 <i>μ</i> s             | 8.8 <i>µ</i> s≇              | fprs/8               |                   |                   |                    |                          |
| 0   | 1                 | 0   | 0   | 0   | 132/fprs             |                 | 13.2 <i>μ</i> s             | 6.6 <i>μ</i> s <sup>≇</sup>  | fprs/6               |                   |                   |                    |                          |
| 0   | 1                 | 1   | 0   | 0   | 88/fprs              |                 | 8.8 <i>μ</i> s <sup>≇</sup> | 禁止设置                         | fprs/4               |                   |                   |                    |                          |
| 1   | 0                 | 0   | 0   | 0   | 66/fprs              | 33.0 <i>μ</i> s | 6.6 μs <sup>±</sup>         |                              | fprs/3               |                   |                   |                    |                          |
| 1   | 0                 | 1   | 0   | 0   | 44/f <sub>PRS</sub>  | 22.0 μs         | 禁止设置                        |                              | fprs/2               |                   |                   |                    |                          |
|     | 其它情况              |     |     |     |                      | 禁止设置            |                             |                              |                      |                   |                   |                    |                          |

**注:** 只有当 4.0 V ≤ AVREF ≤ 5.5 V 时,才能设置

# (2) $2.3 \text{ V} \leq \text{AV}_{\text{REF}} < 2.7 \text{ V}$

| A/I | A/D 转换器模式寄存器(ADM) |     |     |     |          | 转换时间的选                   | 上择              | 转换时钟    |                   | 转换时                | 寸间配置               |                          |
|-----|-------------------|-----|-----|-----|----------|--------------------------|-----------------|---------|-------------------|--------------------|--------------------|--------------------------|
| FR2 | FR1               | FR0 | LV1 | LV0 |          | f <sub>PRS</sub> = 2 MHz | fers =<br>5 MHz | (fad)   | SAR 清<br>零        | 采样                 | 逐次转换时间             | ADCR 传<br>送, INTAD<br>产生 |
| 0   | 0                 | 0   | 0   | 1   | 480/fprs | 禁止设置                     | 禁止设置            | fprs/12 | 2/f <sub>AD</sub> | 24/f <sub>AD</sub> | 12/f <sub>AD</sub> | 2/f <sub>AD</sub>        |
| 0   | 0                 | 1   | 0   | 1   | 320/fprs |                          | 64.0 <i>μ</i> s | fprs/8  |                   |                    |                    |                          |
| 0   | 1                 | 0   | 0   | 1   | 240/fprs |                          | 48.0 <i>μ</i> s | fprs/6  |                   |                    |                    |                          |
| 0   | 1                 | 1   | 0   | 1   | 160/fprs |                          | 32.0 <i>μ</i> s | fprs/4  |                   |                    |                    |                          |
| 1   | 0                 | 0   | 0   | 1   | 120/fprs | 60.0 μs                  | 禁止设置            | fprs/3  |                   |                    |                    |                          |
| 1   | 0                 | 1   | 0   | 1   | 80/fprs  | 40.0 μs                  | 禁止设置            | fprs/2  |                   |                    |                    |                          |
|     | 其它情况              |     |     |     | 禁止设置     |                          |                 |         |                   |                    |                    |                          |

# 注意事项: 1. 根据以下条件设置转换时间

- 4.0 V ≤ AVREF ≤ 5.5 V: 采样时间+ 逐次转换时间 = 5 ~ 30 μs (fad = 0.6 ~ 3.6 MHz)
- 2.7 V ≤ AV<sub>REF</sub> < 4.0 V: 采样时间 + 逐次转换时间 = 10 ~ 30 μs (f<sub>AD</sub> = 0.6 ~ 1.8 MHz)
- 2.3 V ≤ AV<sub>REF</sub> < 2.7 V: 采样时间 + 连续转换时间 = 25 ~ 62 μs (f<sub>AD</sub> = 0.6 ~ 1.48 MHz)
- 2. 当修改 FR2~FR0, LV1 和 LV0 为其他值时, 要预先停止 A/D 转换一次 (ADCS = 0)。
- 3. 当 2.3 V ≤ AVREF < 2.7 V 时,修改 LV1 和 LV0 的默认值。
- 4. 上述的转换时间不包括时钟频率误差。在选择转换时间的时候,要将时钟频率误差考虑进去。

备注: fprs: 外部硬件时钟频率



图 13-5. A/D 转换器采样和 A/D 转换时序

# 注: 等待周期的详细信息参见第三十二章 等待注意事项

# (2) 10 位 A/D 转换结果寄存器 (ADCR)

这是一个 16 位寄存器,用来存储 A/D 转换结果。寄存器的低 6 位恒为 0。每次 A/D 转换结束时,将转换结果从逐次逼近寄存器传送至 ADCR 中。转换结果的高 8 位存储在 FF09H 中,而转换结果的低 2 位存储在 FF08H 的高 2 位中。

可由 16 位存储器操作指令读取 ADCR。

复位信号产生将该寄存器清零(0000H)。

图 13-6 10 位 A/D 转换结果寄存器(ADCR)的格式

地址: FF08H,FF09H 复位后: 0000H R



- 注意事项: 1. 在对 A/D 转换器模式寄存器(ADM)和模拟输入通道选择寄存器(ADS)和 A/D 端口配置寄存器(ADPC) 赋值时,ADCR 的内容可能是不确定的。转换结束后先读取转换结果,再对 ADM, ADS 和 ADPC 赋值。如果没有按照上述时序,可能会读取到不正确的转换结果。
  - 2. 如果从 ADCR 读取数据,会产生一个等待周期。当 CPU 工作在子系统时钟,且外部硬件时钟处于停止状态时,不要从 ADCR 读取数据。需要了解详细信息,可参阅第三十二章 等待注意事项。

# (3) 8 位 A/D 转换结果寄存器 (ADCRH)

这是一个 8 位寄存器,用来存储 A/D 转换结果。可以存储 10 位分辨率的高 8 位。可由 8 位存储器操作指令读取 ADCRH。 复位信号产生将该寄存器清零(00H)。

#### 图 13-7 8 位 A/D 转换结果寄存器(ADCRH) 的格式

| 地址: FF | 09H | 复位后: 00 | )H R |   |   |   |   |   |
|--------|-----|---------|------|---|---|---|---|---|
| 符号     | 7   | 6       | 5    | 4 | 3 | 2 | 1 | 0 |
| ADCRH  |     |         |      |   |   |   |   |   |

- 注意事项: 1. 在对 A/D 转换器模式寄存器(ADM)、模拟输入通道选择寄存器(ADS)和 A/D 端口配置寄存器(ADPC) 赋值时, ADCRH 的内容可能不确定。转换结束后先读取转换结果,再对 ADM、ADS 和 ADPC 赋值。如果没有按照上述时序,可能会读取到不正确的转换结果。
  - 2. 如果从 ADCRH 读取数据,会产生一个等待周期。当 CPU 工作在子系统时钟,且外部硬件时钟处于停止状态时,不要从 ADCRH 读取数据。需要了解详细信息,可参阅第三十二章 等待注意事项。

# (4) 模拟输入通道选择寄存器 (ADS)

该寄存器用来选择被转换的模拟电压的输入通道。 可由 1 位或 8 位存储器操作指令设置 ADS。 复位信号产生将该寄存器清零(00H)。

#### 图 13-8. 模拟输入通道选择寄存器 (ADS)的格式

地址: FF29H 复位后: 00H R/W

符号 6 5 4 3 2 1 0
ADS 0 0 0 0 ADS2 ADS1 ADS0

| ADS2 | ADS1 | ADS0 | 模拟输入通道的选择 |
|------|------|------|-----------|
| 0    | 0    | 0    | ANI0      |
| 0    | 0    | 1    | ANI1      |
| 0    | 1    | 0    | ANI2      |
| 0    | 1    | 1    | ANI3      |
| 1    | 0    | 0    | ANI4      |
| 1    | 0    | 1    | ANI5      |
| 1    | 1    | 0    | ANI6      |
| 1    | 1    | 1    | ANI7      |

注意事项: 1. 第3~7位必须清零。

- k 2 使用端口模式寄存器 2(PM2)设置一个用于 A/D 转换通道的端口为输入模式。
- ★ 3. 不要通过 ADPC 和 ADS 设置数字 I/O 引脚。
  - 4. 如果对 ADS 赋值,会产生一个等待周期。当 CPU 工作在子系统时钟,且外部硬件时钟处于停止状态时,不要对 ADS 赋值。需要了解详细信息,可参阅第三十二章 等待注意事项。

# (5) A/D 端口配置寄存器 (ADPC)

ADPC

★ 这个寄存器用于将 ANIO/P20 ~ ANI7/P27 引脚切换为 A/D 转换器的模拟输入或者数字 I/O 端口。可由 1 位或 8 位存储器操作指令设置 ADPC。 复位信号产生将该寄存器清零(00H)。

## 图 13-9 A/D 端口配置寄存器(ADPC)的格式

 地址: FF2FH
 复位后: 00H R/W

 符号
 7
 6
 5
 4
 3
 2
 1
 0

| ADPC3 | ADPC2 | ADPC1 | ADPC0 |              | 模拟输入(A)/数字 I/O(D)的切换 |              |              |              |              |              |              |  |
|-------|-------|-------|-------|--------------|----------------------|--------------|--------------|--------------|--------------|--------------|--------------|--|
|       |       |       |       | ANI7/<br>P27 | ANI6/<br>P26         | ANI5/<br>P25 | ANI4/<br>P24 | ANI3/<br>P23 | ANI2/<br>P22 | ANI1/<br>P21 | ANI0/<br>P20 |  |
| 0     | 0     | 0     | 0     | Α            | Α                    | Α            | Α            | Α            | Α            | Α            | Α            |  |
| 0     | 0     | 0     | 1     | Α            | Α                    | Α            | Α            | Α            | Α            | Α            | D            |  |
| 0     | 0     | 1     | 0     | Α            | Α                    | Α            | Α            | Α            | Α            | D            | D            |  |
| 0     | 0     | 1     | 1     | Α            | Α                    | Α            | Α            | Α            | D            | D            | D            |  |
| 0     | 1     | 0     | 0     | Α            | Α                    | Α            | Α            | D            | D            | D            | D            |  |
| 0     | 1     | 0     | 1     | Α            | Α                    | Α            | D            | D            | D            | D            | D            |  |
| 0     | 1     | 1     | 0     | Α            | Α                    | D            | D            | D            | D            | D            | D            |  |
| 0     | 1     | 1     | 1     | Α            | D                    | D            | D            | D            | D            | D            | D            |  |
| 1     | 0     | 0     | 0     | D            | D                    | D            | D            | D            | D            | D            | D            |  |
|       | 其它情况  |       |       |              |                      |              | 禁止设置         |              |              |              |              |  |

ADPC3

ADPC2

ADPC1

ADPC0

- ★ 注意事项: 1. 用端口模式寄存器 2(PM2)设置一个用于 A/D 转换通道的端口为输入模式。
- 2. 不要使用 ADPC 和 ADS 上设置数字 I/O 引脚。
  - 3. 如果将数据写入 ADPC, 会产生一个等待周期。当 CPU 工作在子系统时钟,且外部硬件时钟处于停止状态时,不要将数据写入 ADPC。需要了解详细信息,可参阅第三十二章 等待注意事项。

# (6) 端口模式寄存器 2 (PM2)

在使用 ANI0/P20  $\sim$  ANI7/P27 引脚作为模拟输入端口时,将 PM20  $\sim$  PM27 设为 1。此时 P20  $\sim$  P27 的输出锁存器的内容为 0 或 1。

如果将 PM20  $\sim$  PM27 设为 0,则它们不能用作模拟输入端口引脚。

可由 1 位或 8 位的存储器操作指令来设置 PM2。

复位信号产生将该寄存器设置为 FFH。

## 图 13-10 端口模式寄存器 2 (PM2)的格式

地址: FF22H 复位后: FFH R/W

| 符号  | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| PM2 | PM27 | PM26 | PM25 | PM24 | PM23 | PM22 | PM21 | PM20 |

| PM2n | P2n 引脚 I/O 模式的选择(n = 0∼7) |
|------|---------------------------|
| 0    | 输出模式(输出缓冲器打开)             |
| 1    | 输入模式(输出缓冲器关闭)             |

根据 ADPC、ADS 和 PM2 的设置,ANIO/P20 ~ANI7/P27 引脚功能如下所示。

图 13-3 ANIO/P20 ~ ANI7/P27 引脚功能的设置

| ADPC       | PM2  | ADS     | ANI0/P20 ~ ANI7/P27 引脚 |
|------------|------|---------|------------------------|
| 模拟输入的选择    | 输入模式 | 选择 ANI  | 模拟输入 (被转换)             |
|            |      | 不选择 ANI | 模拟输入 (不被转换)            |
|            | 输出模式 | 选择 ANI  | 禁止设置                   |
|            |      | 不选择 ANI |                        |
| 数字 I/O 的选择 | 输入模式 | 选择 ANI  | 禁止设置                   |
|            |      | 不选择 ANI | 数字输入                   |
|            | 输出模式 | 选择 ANI  | 禁止设置                   |
|            |      | 不选择 ANI | 数字输出                   |

#### 13.4 A/D 转换器的操作

## ★ 13.4.1 A/D 转换器的基本操作

- <1> 把 A/D 转换器模式寄存器的第 0 位(ADCE)置 1 启动比较器的操作。
- <2> 通过 A/D 端口配置寄存器设置通道,用于 A/D 转换的模拟输入,并且通过端口模式寄存器 2(PM2)设置为输入模式。
- <3> 根据 ADM 的第 5~1 位(FR2 ~ FR0、LV1 和 LV0)设置 A/D 转换时间。
- <4> 通过模拟输入通道选择寄存器(ADS)选择一个通道用于 A/D 转换
- <5> 设置 ADM 的第7位(ADCS)为 1, 启动转换操作。
  - $(<6> \sim <12>$  的操作由硬件完成)
- <6> 由采样&保持电路对输入到已选中的模拟输入通道的电压进行采样。
- <7> 在经过一定时间的采样后,采样&保持电路处于保持状态,且在 A/D 转换操作结束前一直保持采样电压。
- <8> 设置逐次逼近寄存器(SAR)的第9位。通过分接选择器将串联电阻串的分接电压置为(1/2) AVREF。
- <9> 由电压比较器比较串联电阻串的分接电压与采样电压。如果模拟输入电压高于(1/2) AVREF,则 SAR 的 MSB =1; 如果模拟输入电压低于(1/2) AVREF,则 SAR 的 MSB = 0。
- <10> 接下来, SAR 的第 8 位自动置 1,并进入下一个比较过程。根据第 9 位的预置值选择串联电阻串的分接电压,具体描述如下。
  - 第9位=1: (3/4) AVREF
  - 第9位=0: (1/4) AVREF

比较分接电压与采样电压,并设置 SAR 的第8位,如下所示。

- 模拟输入电压≥分接电压:第8位=1
- 模拟输入电压 < 分接电压: 第8位 = 0
- <11> 按此方式继续进行比较,直至 SAR 的第 0 位。
- <12> 全部 10 位比较完成后,在 SAR 中保留一个有效的数值结果,然后将结果传送至 A/D 转换结果寄存器(ADCR, ADCRH)中,并锁存。

同时也会产生 A/D 转换结束中断请求 (INTAD)。

<13> 反复执行步骤 <6> ~ <12>, 直至 ADCS 被清零(0)。

将 ADCS 清零,以停止 A/D 转换器操作。

当 ADCE = 1 时,若要重新启动 A/D 转换操作,应从步骤<5>开始。当 ADCE = 0 时,若要再次启动 A/D 转换操作,设置 ADCE=1,等待至少 1  $\mu$ S,然后从步骤<5>开始操作。如要改变 A/D 转换的通道,则从步骤<4>开始。

#### 注意事项: 必须确保 <1> $\sim$ <5> 的操作时间至少为 1 $\mu$ S 。

备注: 有两种类型的 A/D 转换结果寄存器可以使用。

- ADCR (16 位): 存储 10 位 A/D 转换值
- ADCRH (8 位): 存储 8 位 A/D 转换值

# 图 13-11 A/D 转换器的基本操作



直到用软件将 A/D 转换器模式寄存器(ADM)的第7位(ADCS)复位(0),连续执行 A/D 转换操作。

★ 在 A/D 转换期间,如果对模拟输入通道选择寄存器(ADS)进行写操作,则转换操作被初始化,并且若 ADCS 被设置 为 1,则转换操作重新开始。

复位信号产生将 A/D 转换结果寄存器(ADCR)的内容设置为 0000H 或 00H。

# 13.4.2 输入电压和转换结果

输入到模拟输入引脚(ANIO  $\sim$  ANI7)的模拟输入电压与理论上的 A/D 转换结果(存储在 10 位 A/D 转换结果寄存器 (ADCR)中)之间的关系表示如下。

$$SAR = INT \left( \frac{V_{AIN}}{AV_{REF}} \times 1024 + 0.5 \right)$$
 
$$ADCR = SAR \times 64$$

或

$$(\frac{\mathsf{ADCR}}{\mathsf{64}} - 0.5) \times \frac{\mathsf{AVREF}}{\mathsf{1024}} \ \leq V_{\mathsf{AIN}} < (\ \frac{\mathsf{ADCR}}{\mathsf{64}} \ + 0.5) \times \ \frac{\mathsf{AVREF}}{\mathsf{1024}}$$

其中, INT(): 该函数返回括号中值的整数部分。

Vain: 模拟输入电压 AVref: AVref 引脚电压

ADCR: A/D 转换结果寄存器(ADCR)的值

SAR: 逐次逼近寄存器

图 13-12 显示模拟输入电压与 A/D 转换结果之间的关系。

图 13-12 模拟输入电压和 A/D 转换结果之间的关系



A/D 转换结果

# 13.4.3 A/D 转换器操作模式

A/D 转换器的操作模式为选择模式。由模拟输入通道选择寄存器(ADS)从 ANIO  $\sim$  ANI7 中选择一个模拟输入通道,并执行 A/D 转换。

## (1) A/D 转换操作

通过将 A/D 转换器模式寄存器(ADM)的第 7 位(ADCS)置 1,可启动电压的 A/D 转换操作,该电压由模拟输入通道选择寄存器(ADS)选择的模拟输入引脚输入。

当 A/D 转换完成时,将 A/D 转换结果存于 A/D 转换结果寄存器(ADCR)中,并产生一个中断请求信号(INTAD)。当一个 A/D 转换结束时,下一个 A/D 转换操作将立即开始。

如果在 A/D 转换期间 ADS 的值被重写,则停止当前正在执行的 A/D 转换操作,重新开始。

如果在 A/D 转换期间 ADCS 被置 0,则 A/D 转换立即停止。此时,之前的转换结果立即被保存。



图 13-13 A/D 转换操作

备注:

1.  $n = 0 \sim 7$ 

**2.**  $m = 0 \sim 7$ 

#### ★ 设置方法描述如下。

- <1> 设置 A/D 转换器模式寄存器(ADM)的第 0 位(ADCE)为 1。
- <2> 根据 A/D 端口配置寄存器的第  $3\sim0$  位(ADPC3  $\sim$  ADPC0)和端口模式寄存器 2(PM2)的第  $7\sim0$  位 (PM27  $\sim$  PM20),设置在模拟输入模式下使用的通道。
- <3> 根据 ADM 的第 5~1 位(FR2 ~ FR0、LV1 和 LV0)选择转换时间。
- <4> 使用模拟输入通道选择寄存器(ADS)的第  $2\sim0$  位(ADS2  $\sim$  ADS0),选择通道。
- <5> 将 ADM 的第 7 位 (ADCS)置 1, 启动 A/D 转换操作。
- <6> 当 A/D 转换结束,产生一个中断请求信号(INTAD)。
- <7> 将 A/D 转换数据传送至 A/D 转换结果寄存器(ADCR, ADCRH)中。

#### <改变通道>

- <8> 根据 ADS 的第 2 $\sim$ 0 位(ADS2  $\sim$  ADS0)改变通道,启动 A/D 转换操作。
- <9> 当 A/D 转换结束,产生一个中断请求信号(INTAD)。
- <10>将 A/D 转换数据传送至 A/D 转换结果寄存器(ADCR, ADCRH)中。

#### <完成 A/D 转换>

- <11> 将 ADCS 清零。
- <12> 将 ADCE 清零。
- 注意事项: 1. 必须确保步骤 <1> ~ <3>的操作时间至少为 1 µs。
  - 2. <1> 可以在<2> 和 <4>之间进行.
  - 3. <1>可以被省略。但在这种情况中(<5>之后)忽略第一个转换结果。
  - 4. 步骤<6>  $\sim$  <9>所经历的时间与使用 ADM 的第  $5\sim$ 1 位(FR2  $\sim$  FR0,LV1,LV0)设置的转换时间不同。步骤<8>  $\sim$  <9>所经历的时间为 FR2  $\sim$  FR0,LV1,LV0 设置的转换时间。

# 13.5 A/D 转换器特征表的阅读方法

以下介绍 A/D 转换器中的专用术语。

#### (1) 分辨率

这是可识别的最小的模拟输入电压,即每位数字输出的模拟输入电压的百分比,称为 ILSB(最低有效位)。对于满度的 ILSB 的百分比用%FSR(满度范围)表示。

当分辨率为 10 位时 1LSB 表示如下。

$$1LSB = 1/2^{10} = 1/1024$$
  
= 0.098%FSR

精确度与分辨率无关,而由总误差决定。

# (2) 总误差

总误差是指实际测量值与理论值之间的最大误差。

零度误差、满度误差、积分线性误差和微分线性误差等组合起来表示总误差。

注意量化误差不属于特征表中总误差的范围。

#### (3) 量化误差

当模拟值转换成数字值时,通常会产生±1/2LSB 的误差。在一个 A/D 转换器中,相差±1/2LSB 的模拟输入电压被转换成相同的数字代码,因此量化误差不可避免。

注意量化误差不属于特征表中总误差、零度误差、满度误差、积分线性误差和微分线性误差的范围。

图 13-14. 总误差



图 13-15. 量化误差



# (4) 零度误差

零度误差表示当数字输出范围在  $0.....000 \sim 0.....001$  之间时模拟输入电压的实际测量值与理论值(1/2LSB)之间的误差。

如果实际测量值大于理论值,零度误差表示当数字输出范围在  $0......001 \sim 0......010$  之间时模拟输入电压的实际测量值与理论值(3/2LSB)之间的误差。

# (5) 满度误差

满度误差表示当数字输出范围在  $1.....110 \sim 1.....111$  之间时模拟输入电压的实际测量值与理论值(满度 -3/2LSB)之间的误差。

## (6) 积分线性误差

积分线性误差说明了转换特征偏离理想线性关系的程度。它表示当零度误差和满度误差均为 0 时实际测量值与理想直线之间误差的最大值。

# (7) 微分线性误差

当代码输出的理想宽度为 1LSB 时, 微分线性误差表示实际测量值与理想值之间的差距。

图 13-16 零度误差



图 13-18 积分线性误差



图 13-17 满度误差



图 13-19 微分线性误差



#### (8) 转换时间

转换时间表示从开始采样到获取数字输出所经历的时间。 采样时间包含在特征表中的转换时间中。

#### (9) 采样时间

采样时间表示模拟电压的模拟开关被打开到模拟电压被采样&保持电路采样所需的时间。



# 13.6 A/D 转换器使用注意事项

# (1) STOP 模式中的操作电流

在 STOP 模式中 A/D 转换器停止操作。此时,将 A/D 转换器模式寄存器(ADM)的第 7 位(ADCS)和第 0 位(ADCE)清零,可以降低操作电流。

若要从待机状态重新启动,将中断请求标志寄存器 1L (IF1L)的第 0 位(ADIF)清零(0),然后开始操作。

#### (2) ANI0 ~ ANI7 的输入范围

观察 ANIO ~ ANI7 输入电压的额定范围。如果输入到模拟输入通道的电压大于等于 AVREF,或者小于等于 AVss(即使在绝对最大额定范围之内),则该通道的转换值不确定。此外,其它通道的转换值也可能会受影响。

#### (3) 冲突操作

<1> 转换结束后,通过指令对 A/D 转换结果寄存器(ADCR, ADCRH)的写操作和 ADCR 或 ADCRH 的写操作之间的冲突。

ADCR 或 ADCRH 读操作的优先级高。在执行读操作后,才将新的转换结果写入 ADCR 或 ADCRH。

<2> 转换结束后,ADCR 或 ADCRH 的写操作、A/D 转换器模式寄存器(ADM)的写操作以及模拟输入通道选择寄存器(ADS)或 A/D 端口配置寄存器(ADPC)的写操作之间的冲突。

ADM、ADS 或 ADPC 的写操作的优先级高。不执行 ADCR 或 ADCRH 的写操作,也不会产生转换结束中断信号(INTAD)。

#### ★(4) 解决噪音问题的方法

为了保持 10 位分辨率,必须注意输入到 AVREF 引脚和 ANIO~ANI7 引脚的噪音。

- <1> 连接一个低等效电阻的电容和一个优质频率响应到电源上
- <2> 模拟输入源的输出阻抗越大,干扰就越大。为了降低噪音,建议按图 13-20 所示连接外部 C。
- <3> 在转换过程中不要切换引脚。
- <4> 如果在转换开始后立即设置 HALT 模式,则可以改善精度。

#### 图 13-20 模拟输入引脚连接



#### (5) ANI0/P20 $\sim$ ANI7/P27

- <1> 模拟输入引脚(ANI0  $\sim$  ANI7)也可用作输入端口引脚(P20  $\sim$  P27)。 当选择 ANI0  $\sim$  ANI7 中的任意一个通道执行 A/D 转换时,转换过程中不要访问 P20  $\sim$  P27; 否则转换分辨率可能会降低。建议从 ANI0/P20(离 AVREF 最远)开始,选择引脚用作 P20  $\sim$  P27。
- <2> 如果正在进行 A/D 转换的引脚的相邻引脚有数字脉冲,则由于噪音耦合,有可能得不到预期的 A/D 转换值。 因此在进行 A/D 转换时不要在相邻引脚引用脉冲。

# (6) ANIO ~ ANI7 引脚的输入阻抗

采样期间 A/D 转换器对采样电容充电,以便进行采样。

因此当不进行采样时仅有漏电流经过,而在采样期间则有为电容充电的电流,因此根据是否进行采样,输入阻抗会波动,且无法解决。

为了使采样有效,建议模拟输入源的输出阻抗小于等于 10 kΩ,并将一个 100 pF 左右 的电容连接到 ANIO  $\sim$  ANI7 引脚上(参见 **图 13-20**)。

## (7) AVREF 引脚输入阻抗

在 AVREF与 AVss 引脚之间连接几十千欧的串联电阻串。

因此,如果参考电压源的输出阻抗很高,当它串联连接到 AVREF 与 AVSS 引脚之间的串联电阻串时,会导致较大的参考电压误差。

#### (8) 中断请求标志(ADIF)

即使模拟输入通道选择寄存器(ADS)的值被修改,中断请求标志(ADIF)也不会被清零。

因此,如果在 A/D 转换期间有一个模拟输入引脚发生变化,则在 ADS 被修改之前,模拟输入通道的 A/D 转换结果和改变前的模拟通道的 ADIF 可能被设置。此时需要注意是,当 ADS 修改后立即读取 ADIF 时,即使修改后的模拟输入的 A/D 转换尚未结束,也会设置 ADIF。

当 A/D 转换停止后又重新开始时,在启动前先对 ADIF 清零。

修改 ADS 修改 ADS 设置 ADIF (ANIn 开始转换) (ANIm 开始转换) 但 ADIm 转换还未结束 A/D 转换 ANIn ANIn ANIm ANIm **ADCR** ANIn ANIn **ANIm** ANIm ADIF

图 13-21. A/D 转换结束中断请求产生的时序

备注:

- 1.  $n = 0 \sim 7$
- **2.**  $m = 0 \sim 7$

#### (9) A/D 转换刚开始时的转换结果

在 A/D 转换开始后,若在 ADCE 置 1 后的 1  $\mu$ s 内对 ADCS 置 1,或者 ADCE=0 时 ADCS 置 1,那么第一次的 A/D 转换值可能不在额定范围内。可采取措施,如悬挂 A/D 转换结束中断请求(INTAD),并删除第 1 次转换结果。

#### (10) A/D 转换结果寄存器(ADCR, ADCRH)的读取操作

当对 A/D 转换器模式寄存器(ADM)、模拟输入通道选择寄存器(ADS)和 A/D 端口配置寄存器(ADPC)进行写操作时, ADCR 和 ADCRH 的内容可能不确定。在对 ADM、ADS 和 ADPC 进行写操作前且转换结束后读取转换结果。如果采用与上述不同的时序操作可能会读取到不正确的转换结果。

# ★ (11) 内部等效电路

模拟输入模块的等效电路如下所示。

图 13-22 ANIn 引脚的内部等效电路



表 13-4 等效电路的电阻和电容 (参考值)

| AVREF                                                       | R1     | C1   | C2   |
|-------------------------------------------------------------|--------|------|------|
| 4.0 V ≤ AV <sub>REF</sub> ≤ 5.5 V                           | 8.1 kΩ | 8 pF | 5 pF |
| 2.7 V ≤ AV <sub>REF</sub> < 4.0 V                           | 31 kΩ  | 8 pF | 5 pF |
| $2.3 \text{ V} \leq \text{AV}_{\text{REF}} < 2.7 \text{ V}$ | 381 kΩ | 8 pF | 5 pF |

**备注:** 1. 表 13-4 所显示的电阻和电容值仅为参考值。

2.  $n = 0 \sim 7$ 

# 第十四章 串行接口 UARTO

# 14.1 串行接口 UARTO 的功能

串行接口 UARTO 有以下两种模式。

#### (1) 操作停止模式

这个模式在不进行串口通信时使用,以降低功耗。 需要了解详细信息,请参阅 **14.4.1 操作停止模式。** 

#### (2) 异步串行接口(UART)模式

该模式的功能概括如下。

需要了解详细信息,请参阅 14.4.2 异步串行接口(UART)模式和 14.4.3 专用波特率发生器。

- ★ 最大传输率: 312.5kbps
  - 双引脚配置 TXD0: 发送数据输出引脚 RxD0: 接收数据输入引脚
  - 可选择通信数据的宽度为7或8位。
  - 专用内置 5 位波特率发生器,允许设置任意大小的波特率。
  - 可分别执行发送和接收操作(全双工操作)。
  - 恒为 LSB-first 通信
  - 注意事项: 1. 如果串行接口 UART0 使用的时钟未停止(例如处于 HALT 模式下),则可继续正常操作。如果时钟已停止(例如处于 STOP 模式下),则每个寄存器都停止操作,并且在时钟停止之前及时保存数据。 TxD0 引脚在时钟停止之前立即保存数据并输出。但在时钟恢复使用后的操作不能得到保证。因此必须复位电路,使 POWER0 = 0、RXE0 = 0 以及 TXE0 = 0。
    - 2. 先设置 POWER0 = 1, 然后设置 TXE0 = 1(发送)或 RXE0 = 1(接收)开始通信。
    - 3. 由 BRGC0 设置基本时钟(fxclk0), 可使 TXE0 与 RXE0 同步。为了能够再次发送或接收,在 TXE0 或 RXE0 被清零后,至少要经历两个基本时钟再将 TXE0 或 RXE0 置 1。如果在不到两个基本时钟时设置 TXE0 或 RXE0,则发送或接收电路可能不被初始化。
- \* 4. 设置 TXE0=1 之后经过至少一个基本时钟才能发送数据到 TXS0。

# 14.2 串行接口 UART0 的配置

串行接口 UARTO 包括以下硬件。

表 14-1 串行接口 UART0 的配置

| スロー TIXI UAKIV IIII E |                                                                                                                  |  |  |  |  |  |
|-----------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 项目                    | 配置                                                                                                               |  |  |  |  |  |
| 寄存器                   | 接收缓冲寄存器 0 (RXB0)<br>接收移位寄存器 0 (RXS0)<br>发送移位寄存器 0 (TXS0)                                                         |  |  |  |  |  |
| 控制寄存器                 | 异步串行接口操作模式寄存器 0 (ASIM0)<br>异步串行接口接收错误状态寄存器 0 (ASIS0)<br>波特率发生器控制寄存器 0 (BRGC0)<br>端口模式寄存器 1 (PM1)<br>端口寄存器 1 (P1) |  |  |  |  |  |



314

# (1) 接收缓冲寄存器 0 (RXB0)

该 8 位寄存器用于存储由接收移位寄存器 0(RXS0)转换的并行数据。 每接收到 1 字节的数据,新的接收数据就从接收移位寄存器 0(RXS0)被传送到该寄存器中。 如果数据宽度被设定为 7 位,则将接收到的数据传送到 RXB0 的  $0 \sim 6$  位,而 MSB 位恒为 0。 如果出现溢出错误(OVE0),则不把接收数据传送到 RXB0 中。 可由 8 位存储器操作指令读取 RXB0 的内容。不能将数据写入该寄存器中。 复位信号的产生和 POWER0 = 0 将该寄存器设置为 FFH。

#### (2) 接收移位寄存器 0 (RXS0)

该寄存器将输入到 RxD0 引脚的串行数据转换成并行数据。程序不能直接使用 RXS0。

#### (3) 发送移位寄存器 0 (TXS0)

该寄存器用于设置发送数据。当数据写入 TXS0 时启动发送操作,串行数据从 TxD0 引脚输出。可由 8 位存储器操作指令对 TXS0 进行写操作。该寄存器的内容不能被读取。 复位信号的产生、POWER0=0或 TXE0=0将该寄存器设置为 FFH。

★ 注意事项 1.设置 TXE0=1 之后经过至少一个基本时钟(fxclко)才能发送数据到 TXS0。
2.在发送完成中断信号(INTST0)产生之前,不要把下一个发送数据写入 TXS0。

# 14.3 控制串行接口 UART0 的寄存器

串行接口 UARTO 由以下 5 个寄存器控制。

- 异步串行接口操作模式寄存器 0 (ASIM0)
- 异步串行接口接收错误状态寄存器 0 (ASIS0)
- 波特率发生器控制寄存器 0 (BRGC0)
- 端口模式寄存器 1 (PM1)
- 端口寄存器 1 (P1)

# (1) 异步串行接口操作模式寄存器 0 (ASIM0)

该8位寄存器用于控制串行接口 UARTO 的串行通信操作。 该寄存器可由1位或8位存储器操作指令设置。 复位信号的产生将该寄存器设置为01H。

# 图 14-2 异步串行接口操作模式寄存器 0 (ASIM0)的格式 (1/2)

地址: FF70H 复位后: 01H R/W

| 符号    | <7>    | <6>  | <5>  | 4    | 3    | 2   | 1   | 0 |
|-------|--------|------|------|------|------|-----|-----|---|
| ASIM0 | POWER0 | TXE0 | RXE0 | PS01 | PS00 | CL0 | SL0 | 1 |

|   | POWER0 | 内部操作时钟的允许/禁止操作                  |
|---|--------|---------------------------------|
| I | 0 #1   | 禁止内部操作时钟的操作(时钟恒为低电平)并异步复位内部电路推2 |
|   | 1      | 允许内部操作时钟的操作                     |

| TXE0 | 允许/禁止发送        |
|------|----------------|
| 0    | 禁止发送(同步复位发送电路) |
| 1    | 允许发送           |

| RXE0 | 允许/禁止接收         |  |  |  |  |
|------|-----------------|--|--|--|--|
| 0    | 禁止接收 (同步复位接收电路) |  |  |  |  |
| 1    | 允许接收            |  |  |  |  |

# 注: 1. 当 POWER0 = 0 时,从 RxD0 引脚输入的信号恒为高电平。

2. 对异步串行接口接收错误状态寄存器 0(ASIS0)、发送移位寄存器 0(TXS0)和接收缓冲寄存器 0(RXB0)进行复位。

图 14-2 异步串行接口操作模式寄存器 0 (ASIM0)的格式 (2/2)

| PS01 | PS00 | 发送操作   | 接收操作               |  |  |
|------|------|--------|--------------------|--|--|
| 0    | 0    | 不输出校验位 | 无校验接收              |  |  |
| 0    | 1    | 输出零校验  | 零校验接收 <sup>在</sup> |  |  |
| 1    | 0    | 输出奇校验  | 按奇校验判断             |  |  |
| 1    | 1    | 输出偶校验  | 按偶校验判断             |  |  |

| CL0 | 指定发送/接收数据的字符宽度 |
|-----|----------------|
| 0   | 数据的字符宽度 = 7 位  |
| 1   | 数据的字符宽度 = 8 位  |

| SL0 | 指定发送数据停止位的个数 |
|-----|--------------|
| 0   | 停止位个数 = 1    |
| 1   | 停止位个数=2      |

- **注:** 如果选择"按零校验接收",则无法判断校验。因此不要设置异步串行接口接收错误状态寄存器 0(ASISO)的 第 2 位(PEO),这样就不会产生错误中断。
- 注意事项: 1. 启动发送时,对 POWER0 置 1,然后对 TXE0 置 1。停止发送时,先将 TXE0 清零,然后将 POWER0清零。
  - 2. 启动接收时,对 POWER0 置 1, 然后对 RXE0 置 1。停止接收时, 先将 RXE0 清零, 然后将 POWER0 清零。
  - 3. 当 RxD0 引脚输入为高电平时,先对 POWER0 置 1, 再对 RXE0 置 1。当输入为低电平, POWER0 置 1, RXE0 置 1 时, 启动接收操作。
  - 4. 通过 BRGC0 设置的基本时钟(fxclx0)同步 TXE0 与 RXE0。为了能够再次发送或接收,在 TXE0 或 RXE0 被清零后,至少要经历两个基本时钟再将 TXE0 或 RXE0 置 1。如果在不到两个基本时钟的时间内设置 TXE0 或 RXE0,则发送或接收电路可能不被初始化。
  - 5. 设置 ТХЕ0=1 之后经过至少一个基本时钟(fхсLко)才能设置发送数据到 ТХS0。
    - 6. 在对 PS01、PS00 和 CL0 位重写之前, 先将 TXE0 和 RXE0 位清零。
    - 7. 在重写 SL0 位时,必须确保 TXE0 = 0。总是以"停止位的个数=1"的格式执行接收操作,因此不会 受到 SL0 设置值的影响。
    - 8. 第0位必须设置为1。

\*

# (2) 异步串行接口接收错误状态寄存器 0 (ASIS0)

该寄存器用于指示串行接口 UART0 在接收操作完成时出现的错误状态,包括 3 个错误标志位(PE0, FE0, OVE0)。可由 8 位存储器操作指令对该寄存器进行只读操作。

★ 复位信号的产生将 ASIMO 的第 5 位(RXEO)或第 7 位(POWERO)置 0。读取寄存器的值为 00H。如果产生一个接收错误,则先读取 ASISO 再读取接收缓冲寄存器 0(RXBO)以便将出错标志位清零。

# 图 14-3 异步串行接口接收错误状态寄存器 0 (ASISO)的格式

地址: FF73H 复位后: 00H R

| 符号    | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    |
|-------|---|---|---|---|---|-----|-----|------|
| ASIS0 | 0 | 0 | 0 | 0 | 0 | PE0 | FE0 | OVE0 |

| PE0 | 指示校验错误的状态标志位                          |
|-----|---------------------------------------|
| 0   | 如果 POWER0 = 0 且 RXE0 = 0、或者如果读取 ASIS0 |
| 1   | 如果发送数据的校验位与接收完成时的校验位不相等               |

| FE0 | 指示帧错误的状态标志位                           |
|-----|---------------------------------------|
| 0   | 如果 POWER0 = 0 且 RXE0 = 0、或者如果读取 ASIS0 |
| 1   | 如果接收完成时未检测到停止位                        |

| OVE0 | 指示溢出错误的状态标志位                          |
|------|---------------------------------------|
| 0    | 如果 POWER0 = 0 且 RXE0 = 0、或者如果读取 ASIS0 |
| 1    | 如果接收数据被设置在RXB0寄存器中且在读取该数据前下一个接收操作已完成  |

# 注意事项: 1. 根据异步串行接口操作模式寄存器 0(ASIM0)的 PS01 和 PS00 位的内容的不同,对 PE0 位的操作也有 所不同。

- 2. 无论停止位的个数是多少,只能将接收数据的第1位作为停止位进行检测。
- 3. 如果出现溢出错误,则下一个接收数据不写入接收缓冲寄存器 0(RXB0)中,而是被忽略。
- 4. 如果从 ASIS0 读取数据,会产生一个等待周期。当 CPU 采用子系统时钟操作而停止外部硬件时钟时,不要从 ASIS0 读取数据。需要了解详细信息,可参见第三十二章 等待注意事项。

# (3) 波特率发生器控制寄存器 0 (BRGC0)

该寄存器用于选择串行接口 UART0 的基本时钟和 5 位计数器的分频值。可由 8 位存储器操作指令设置 BRGC0。 复位信号的产生将该寄存器设置为 1FH。

#### 图 14-4 波特率发生器控制寄存器 0 (BRGC0)的格式

地址: FF71H 复位后: 1FH R/W

| 符号    | 7     | 6     | 5 | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|---|-------|-------|-------|-------|-------|
| BRGC0 | TPS01 | TPS00 | 0 | MDL04 | MDL03 | MDL02 | MDL01 | MDL00 |

| TPS01 | TPS00 | 基本时钟 (fxclko) 的选择                |              |              |               |               |  |  |  |
|-------|-------|----------------------------------|--------------|--------------|---------------|---------------|--|--|--|
|       |       |                                  | fprs = 2 MHz | fprs = 5 MHz | fprs = 10 MHz | fprs = 20 MHz |  |  |  |
| 0     | 0     | TM50 输出 <sup>建2</sup>            |              |              |               |               |  |  |  |
| 0     | 1     | fprs/2                           | 1 MHz        | 2.5 MHz      | 5 MHz         | 10 MHz        |  |  |  |
| 1     | 0     | fprs/2 <sup>3</sup>              | 250 kHz      | 625 kHz      | 1.25 MHz      | 2.5 MHz       |  |  |  |
| 1     | 1     | f <sub>PRS</sub> /2 <sup>5</sup> | 62.5 kHz     | 156.25 kHz   | 312.5 kHz     | 625 kHz       |  |  |  |

| MDL04 | MDL03 | MDL02 | MDL01 | MDL00 | k  | 5 位计数器输出时钟的选择 |
|-------|-------|-------|-------|-------|----|---------------|
| 0     | 0     | ×     | ×     | ×     | ×  | 禁止设置          |
| 0     | 1     | 0     | 0     | 0     | 8  | fхсько/8      |
| 0     | 1     | 0     | 0     | 1     | 9  | fхсько/9      |
| 0     | 1     | 0     | 1     | 0     | 10 | fхсько/10     |
| •     | •     | •     | •     | •     | •  | •             |
| •     | •     | •     | •     | •     | •  | •             |
| •     | •     | •     | •     | •     | •  | •             |
| •     | •     | •     | •     | •     | •  | •             |
| •     | •     | •     | •     | •     | •  | •             |
| 1     | 1     | 0     | 1     | 0     | 26 | fхсько/26     |
| 1     | 1     | 0     | 1     | 1     | 27 | fхсько/27     |
| 1     | 1     | 1     | 0     | 0     | 28 | fхсько/28     |
| 1     | 1     | 1     | 0     | 1     | 29 | fхсько/29     |
| 1     | 1     | 1     | 1     | 0     | 30 | fхсько/30     |
| 1     | 1     | 1     | 1     | 1     | 31 | fхсько/31     |

# 注:选择 TM50 输出作为基本时钟时,应注意以下几点。

- PWM 模式 (TMC506 = 1)

先启动 8 位定时器/事件计数器 50, 然后设置计数时钟, 使占空比 = 50%。 不论何种模式,都不必将 TO50 作为定时器输出引脚。 注意事项: 1. 在重写 MDL04 ~ MDL00 位时,必须确保 ASIM0 的第 6 位(TXE0)和第 5 位(RXE0) = 0。

2. 波特率为 5 位计数器输出时钟的 1/2。

根据 TPS01 和 TPS00 位选择的基本时钟的频率 备注: **1.** fxclk0:

> 2. fprs: 外部硬件时钟频率

**3.** k: 由 MDL04 ~ MDL00 位设置的值 (k = 8, 9, 10, ..., 31)

**4.** ×: 不必考虑

5. TMC506: 8位定时器模式控制寄存器 50(TMC50)的第 6位 TMC501: TMC50的第1位

# (4) 端口模式寄存器 1 (PM1)

该寄存器按位设置端口1的输入/输出模式。

当 P10/TxD0/SCK10 引脚用于串行接口数据输出时,将 PM10 清零且对 P10 的输出锁存器置 1。

当 P11/RxD0/SI10 引脚用于串行接口数据输入时,将 PM11 置 1。此时 P11 的输出锁存器的值可以等于 0 或 1。

可由 1 位或 8 位存储器操作指令设置 PM1。

复位信号的产生将该寄存器设置为 FFH。

# 图 14-5 端口模式寄存器 1(PM1)的格式

地址: FF21H 复位后: FFH R/W

符号 7 5 4 6

3 2 1 PM1 PM17 PM16 PM15 PM14 PM13 PM12 PM11 PM10

| PM1n | P1n 引脚 I/O 模式选择 (n = 0~7) |
|------|---------------------------|
| 0    | 输出模式 (输出缓冲器打开)            |
| 1    | 输入模式 (输出缓冲器关闭)            |

# 14.4 串行接口 UART0 的操作

串行接口 UARTO 有以下两种模式。

- 操作停止模式
- 异步串行接口(UART)模式

#### 14.4.1 操作停止模式

在此模式下,不能进行串行通信,这样可降低功耗。此外,引脚可作为通用端口引脚使用。通过将 ASIM0 的第 7、6 和 5 位(POWER0、TXE0 和 RXE0)清零,可设置操作停止模式。

# (1) 使用的寄存器

由异步串行接口操作模式寄存器 0(ASIM0)设置操作停止模式。

可由1位或8位存储器操作指令设置ASIM0。

复位信号的产生将该寄存器设置为 01H。

地址: FF70H 复位后: 01H R/W

| 符号    | <7>    | <6>  | <5>  | 4    | 3    | 2   | 1   | 0 |
|-------|--------|------|------|------|------|-----|-----|---|
| ASIM0 | POWER0 | TXE0 | RXE0 | PS01 | PS00 | CL0 | SL0 | 1 |

| POWER0       | 内部操作时钟的允许/禁止操作                      |
|--------------|-------------------------------------|
| 0 <b>#</b> 1 | 禁止内部操作时钟的操作(时钟恒为低电平)且对内部电路进行异步复位 22 |

| TXE0 | 允许/禁止发送        |
|------|----------------|
| 0    | 禁止发送(同步复位发送电路) |

| RXE0 | 允许/禁止接收        |
|------|----------------|
| 0    | 禁止接收(同步复位接收电路) |

- 注: 1. 当 POWER0 = 0 时,从 RxD0 引脚输入的信号恒为高电平。
  - 2. 对异步串行接口接收错误状态寄存器 0(ASIS0)、发送移位寄存器 0(TXS0)和接收缓冲寄存器 0(RXB0)进行复位。

注意事项: TXE0 和 RXE0 清零后再对 POWER0 清零,可设置操作停止模式。 如果要启动发送或接收,设置 POWER0=1,然后设置 TXE0或 RXE0=1。

**备注:** 如果要将 RxD0/SI10/P11 和 TxD0/SCK10/P10 作为通用端口引脚使用,可参见**第五章 端口功能**。

#### 14.4.2 异步串行接口 (UART)模式

此模式下,在起始位后的1字节数据被发送/接收,可执行全双工操作。可使用专用UART波特率发生器,这样通信选择的波特率范围较大。

# (1) 使用的寄存器

- 异步串行接口操作模式寄存器 0 (ASIM0)
- 异步串行接口接收错误状态寄存器 0 (ASIS0)
- 波特率发生器控制寄存器 0 (BRGC0)
- 端口模式寄存器 1 (PM1)
- 端口寄存器 1 (P1)

在UART模式中设置操作的基本过程如下。

- <1> 设置 BRGC0 寄存器 (参见 图 14-4).
- <2> 设置 ASIMO 的 1~4 位 (SL0、CL0、PS00 和 PS01)(参见 图 14-2)。
- <3> 将 ASIM0 的第 7 位(POWER0)置 1。
- <4> 将 ASIM0 的第 6 位 (TXE0)置 1。 → 允许发送。 将 ASIM0 的第 5 位 (RXE0)置 1。 → 允许接收。
- <5> 对 TXS0 寄存器赋值。 → 开始发送数据。

注意事项: 在设置端口模式寄存器和端口寄存器时, 要考虑与通信另一方的关系。

寄存器设置与引脚之间的关系如下所示。

表 14-2 寄存器设置与引脚之间的关系

| POWER0 | TXE0 | RXE0 | PM10 | P10             | PM11 | P11            | UART0 | 引脚功能           |               |  |
|--------|------|------|------|-----------------|------|----------------|-------|----------------|---------------|--|
|        |      |      |      |                 |      |                | 操作    | TxD0/SCK10/P10 | RxD0/SI10/P11 |  |
| 0      | 0    | 0    | ×    | ×               | ×ŧŧ  | × <sup>ž</sup> | 停止    | SCK10/P10      | SI10/P11      |  |
| 1      | 0    | 1    | ×äŧ  | × <sup>ž±</sup> | 1    | ×              | 接收    | SCK10/P10      | RxD0          |  |
|        | 1    | 0    | 0    | 1               | ×ŧŧ  | × <sup>ž</sup> | 发送    | TxD0           | SI10/P11      |  |
|        | 1    | 1    | 0    | 1               | 1    | ×              | 发送/   | TxD0           | RxD0          |  |
|        |      |      |      |                 |      |                | 接收    |                |               |  |

注: 能够作为端口或串行接口 CSI10 使用。

**备注:** ×: 不必考虑

POWER0: 异步串行接口操作模式寄存器 0 (ASIM0)的第7位

TXE0: ASIM0 的第 6 位 RXE0: ASIM0 的第 5 位 PM1×: 端口模式寄存器 P1×: 端口输出锁存器

# (2) 通信操作

#### (a)正常发送/接收数据的格式和波形示例

图 14-6 和 14-7 为正常发送/接收数据的格式和波形示例。

图 14-6 UART 正常发送/接收数据的格式



- 一个数据帧由以下各位组成。
- 起始位 ... 1 位
- 字符位 ... 7 或 8 位 (LSB-first)
- 校验位 ... 偶校验、奇校验、零校验或无校验
- 停止位 ... 1 或 2 位

由异步串行接口操作模式寄存器 0(ASIM0)规定一个数据帧中字符位的宽度、校验方式和停止位的宽度。

#### 图 14-7 UART 正常发送/接收数据波形示例

1. 数据宽度: 8位, 校验位: 偶校验, 停止位: 1位, 通信数据: 55H



2. 数据宽度: 7位, 校验位: 奇校验, 停止位: 2位, 通信数据: 36H



3. 数据宽度: 8位, 校验位: 无, 停止位: 1位, 通信数据: 87H



# (b)校验方式与操作

校验位用于检测数据通信中的位错误。通常在发送和接收两端可采用相同的校验方式。当采用偶校验和奇校验时,可检测到1位(奇数)错误。而采用零校验和无校验时,则不能检测到错误。

# (i) 偶校验

发送

控制发送数据,包括校验位,使得数据中"1"的个数为偶数。 校验位的取值如下。

如果发送数据有奇数个 "1":1 如果发送数据有偶数个 "1":0

接收

计算接收数据(包括校验位)中"1"的个数。如果结果为奇数,则产生校验错误。

#### (ii) 奇校验

发送

与偶校验方式不同, 奇校验用于控制发送数据, 包括校验位, 使得数据中"1"的个数为奇数。 校验位取值如下。

如果发送数据有奇数个"1":0 如果发送数据有偶数个"1":1

接收

计算接收数据(包括校验位)中"1"的个数。如果结果为偶数,则产生校验错误。

# (iii) 零校验

无论发送数据为何值,发送时校验位被清零。

接收数据时不检测校验位。因此无论校验位为何值,都不会产生校验错误。

# (iv) 无校验

发送数据中没有校验位。

进行接收操作时认为接收数据中没有校验位。因此也不会产生校验错误。

## (c)发送

当异步串行接口操作模式寄存器 0(ASIM0)的第 7 位(POWER0)=1 且 ASIM0 的第 6 位(TXE0)=1 时,允许发送。将待发送数据写入发送移位寄存器 0(TXS0),可启动发送操作。起始位、校验位和停止位会自动添加到数据中。

启动发送操作时,先从 TxD0 引脚输出起始位,然后从 LSB 开始依次发送数据其它位。当发送结束时,由 ASIM0 设置的校验位和停止位被添加到数据中,并产生发送完成中断请求(INTST0)。

当下一个待发送数据被写入 TXS0 时,发送操作才结束。

图 14-8 显示了发送完成中断请求(INTST0)的时序。最后一个停止位一输出就产生该中断。

注意事项: 在将待发送数据写入 TXS0 后,在发送完成中断信号(INTST0)产生之前,不要将下一个发送数据写入 TXS0。

图 14-8 发送完成中断请求的时序

#### 1. 停止位宽度: 1



## 2. 停止位宽度: 2



#### (d) 接收

当异步串行接口操作模式寄存器 0(ASIM0)的第 7位(POWER0)=1,然后将 ASIM0 的第 5位(RXE0)置 1 时,允 许接收并对 RxD0 引脚输入进行采样。

当检测到 RxD0 引脚输入的下降沿时波特率发生器的 5 位计数器开始计数。当计数值等于波特率发生器控制寄存器 0 (BRGC0) 的设置值时,再次采样 RxD0 的输入信号 (如图 14-9 中的 反 如果此时 RxD0 为低电平,则认为输入信号为起始位。

当检测到起始位时,开始接收,以设置的波特率将串行数据依次存入接收移位寄存器 0(RXS0)。当接收到停止位时,会产生接收完成中断信号(INTSR0),并且将 RXS0 的数据写入接收缓冲寄存器 0(RXB0)。但如果出现溢出错误,则接收到的数据不写入 RXB0。

即使在接收过程中出现校验错(PE0),接收仍然继续,直至接收到停止位,而在接收完成后会产生一个接收错误中断(INTSR0)。

当接收操作完成且存在接收错误,则产生 INTSR0。

图 14-9 接收完成中断请求时序



- ★ 注意事项: 1. 如果出现接收错误,必须先读取异步串行接口接收错误状态寄存器 0 (ASISO)再读取接收缓冲寄存器 0 (RXBO)的内容,才能对出错标志清零。否则,当接收到下一个数据时会产生溢出错误,而且接收错误状态保持不变。
  - 2. 接收始终按 "停止位的个数 = 1"的情况执行,第2个停止位被忽略。

## (e) 接收错误

在接收期间有三种出错情况:校验错误、帧错误或溢出错误。如果异步串行接口接收错误状态寄存器 0(ASISO)的错误标志位被设置,作为数据接收的结果,则将会产生一个接收错误中断请求信号 (INTSRO)。

在执行接收错误中断服务(INTSR0)时读取 ASIS0 的内容,可确定接收期间出现的是何种错误(参见**图 14-3**)。 读取 ASIS0 后,将其复位为 0。

| 表 14-3 接收错误产生的原因 | 表 14-3 | 接收错误产生 | ‡的原因 |
|------------------|--------|--------|------|
|------------------|--------|--------|------|

| 接收错误 | 原因                                   |
|------|--------------------------------------|
| 校验错误 | 发送数据的校验位与接收数据的校验位不相等                 |
| 帧错误  | 未检测到停止位                              |
| 溢出错误 | 在从接收缓冲寄存器 0(RXB0)中读取数据前已完成下一个数据的接收操作 |

#### (f) 接收数据的噪声过滤器

通过预分频器,使用基本时钟输出,采样 RxD0 信号。

如果两次采样值相同,则匹配检测器的输出会发生变化,并把采样的数据作为输入数据。

噪声过滤器的电路结构如图 14-10 所示,接收操作的内部过程与外部信号状态相比被延迟两个时钟执行。

图 14-10 噪声过滤器电路



#### 14.4.3 专用波特率发生器

专用波特率发生器由一个源时钟选择器和一个 5 位可编程计数器组成,用于产生 UART0 发送/接收的串行时钟。 分别使用不同的 5 位计数器用于发送和接收。

#### (1) 波特率发生器的配置

#### • 基本时钟

该时钟由波特率发生器控制寄存器 0(BRGC0)的第 7 和 6位(TPS01 和 TPS00)选择。当异步串行接口操作模式寄存器 0(ASIM0)的第 7 位(POWER0)=1 时,将该时钟提供给每个模块。该时钟称为基本时钟,它的频率用 fxclko表示。当 POWER0 = 0 时,基本时钟恒为低电平。

## • 发送计数器

当异步串行接口操作模式寄存器 0(ASIM0)的第 7位(POWER0)或第 6位(TXE0) = 0 时,该计数器停止计数,并被清零。

当 POWER0 = 1 且 TXE0 = 1 时计数器开始计数。

当第1个发送数据被写入发送移位寄存器0(TXS0)时,计数器被清零。

#### • 接收计数器

当异步串行接口操作模式寄存器 0(ASIM0)的第 7位(POWER0)或第 5位(RXE0) = 0时,该计数器停止计数,并被清零。

当检测到起始位时, 计数器开始计数。

在收到一帧数据后计数器停止计数,直到下一个起始位被检测到时再重新开始计数。



图 14-11 波特率发生器的配置

备注: POWER0: 异步串行接口操作模式寄存器 0 (ASIM0)的第7位

TXE0: ASIMO 的第 6 位 RXE0: ASIMO 的第 5 位

BRGC0: 波特率发生器控制寄存器 0

#### (2) 串行时钟的产生

使用波特率发生器控制寄存器 0 (BRGC0)可产生串行时钟。

根据 BRGC0 的第7和6位(TPS01和 TPS00),可选择输入给5位计数器的时钟。

根据 BRGC0 的 4~0 位(MDL04~MDL00)选择 5 位计数器的分频值(fxclko/8 ~ fxclko/31)。

\*

表 14-4 TPS01 和 TPS00 的设置值

| TPS01 | TPS00 | 基本时钟 (fxclko) 的选择   |                             |                 |                              |                  |  |  |
|-------|-------|---------------------|-----------------------------|-----------------|------------------------------|------------------|--|--|
|       |       |                     | f <sub>PRS</sub> = 2<br>MHz | fprs = 5<br>MHz | f <sub>PRS</sub> = 10<br>MHz | fprs = 20<br>MHz |  |  |
| 0     | 0     | TM50 输出             |                             |                 |                              |                  |  |  |
| 0     | 1     | f <sub>PRS</sub> /2 | 1 MHz                       | 2.5 MHz         | 5 MHz                        | 10 MHz           |  |  |
| 1     | 0     | fprs/2 <sup>3</sup> | 250 kHz                     | 625 kHz         | 1.25 MHz                     | 2.5 MHz          |  |  |
| 1     | 1     | fprs/2 <sup>5</sup> | 62.5 kHz                    | 156.25<br>kHz   | 312.5 kHz                    | 625 kHz          |  |  |

## (a) 波特率

通过下列公式计算波特率。

fxclko: 根据 BRGCO 的 TPS01 和 TPS00 位选择的基本时钟的频率

k: 根据 BRGC0 的 MDL04  $\sim$  MDL00 位设置的值 (k = 8, 9, 10, ..., 31)

## (b) 波特率误差

通过下列公式计算波特率误差。

注意事项: 1. 在发送过程中必须保持波特率误差在接收方允许的误差范围内。

2. 接收期间的波特率误差必须满足"(4)接收期间允许的波特率范围"中所描述的范围。

目标波特率 = 76,800 bps

## (3) 波特率设置举例

表 14-5 波特率发生器的数据设置

|        | <b>ベエ・・ 仮刊十次工能的が組入</b> 主 |        |         |       |        |        |         |       |        |        |          |       |        |        |          |       |
|--------|--------------------------|--------|---------|-------|--------|--------|---------|-------|--------|--------|----------|-------|--------|--------|----------|-------|
| 波特率    |                          | fprs = | 2.0 MHz |       |        | fprs = | 5.0 MHz |       | 1      | fprs = | 10.0 MHz |       | İ      | fprs = | 20.0 MHz |       |
| [bps]  | TPS01,                   | k      | 计算值     | ERR   | TPS01, | k      | 计算值     | ERR   | TPS01, | k      | 计算值      | ERR   | TPS01, | k      | 计算值      | ERR   |
|        | TPS00                    |        |         | [%]   | TPS00  |        |         | [%]   | TPS00  |        |          | [%]   | TPS00  |        |          | [%]   |
| 4800   | 2                        | 26     | 4808    | 0.16  | 3      | 16     | 4883    | 1.73  | -      | ı      | Ī        | _     | -      | _      | İ        | -     |
| 9600   | 2                        | 13     | 9615    | 0.16  | 3      | 8      | 9766    | 1.73  | 3      | 16     | 9766     | 1.73  | _      | -      | I        | -     |
| 10400  | 2                        | 12     | 10417   | 0.16  | 2      | 30     | 10417   | 0.16  | 3      | 15     | 10417    | 0.16  | 3      | 30     | 10417    | 0.16  |
| 19200  | 1                        | 26     | 19231   | 0.16  | 2      | 16     | 19531   | 1.73  | 3      | 8      | 19531    | 1.73  | 3      | 16     | 19531    | 1.73  |
| 24000  | 1                        | 21     | 23810   | -0.79 | 2      | 13     | 24038   | 0.16  | 2      | 26     | 24038    | 0.16  | 3      | 13     | 24038    | 0.16  |
| 31250  | 1                        | 16     | 31250   | 0     | 2      | 10     | 31250   | 0     | 2      | 20     | 31250    | 0     | 3      | 10     | 31250    | 0     |
| 33660  | 1                        | 15     | 33333   | -0.79 | 2      | 9      | 34722   | 3.34  | 2      | 18     | 34722    | 3.34  | 3      | 9      | 34722    | 3.34  |
| 38400  | 1                        | 13     | 38462   | 0.16  | 2      | 8      | 39063   | 1.73  | 2      | 16     | 39063    | 1.73  | 3      | 8      | 39063    | 1.73  |
| 56000  | 1                        | 9      | 55556   | -0.79 | 1      | 22     | 56818   | 1.46  | 2      | 11     | 56818    | 1.46  | 2      | 22     | 56818    | 1.46  |
| 62500  | 1                        | 8      | 62500   | 0     | 1      | 20     | 62500   | 0     | 2      | 10     | 62500    | 0     | 2      | 20     | 62500    | 0     |
| 76800  | -                        | -      | I       | _     | 1      | 16     | 78125   | 1.73  | 2      | 8      | 78125    | 1.73  | 2      | 16     | 78125    | 1.73  |
| 115200 | _                        | -      | 1       | _     | 1      | 11     | 113636  | -1.36 | 1      | 22     | 113636   | -1.36 | 2      | 11     | 113636   | -1.36 |
| 153600 | 1                        | -      | ı       | -     | 1      | 8      | 156250  | 1.73  | 1      | 16     | 156250   | 1.73  | 2      | 8      | 156250   | 1.73  |

**备注:** TPS01, TPS00: 波特率发生器控制寄存器 0 (BRGC0)的第7和6位 (用于设置基本时钟(fxclko))

k: 根据 BRGC0 的 MDL04  $\sim$  MDL00 位设置的值 (k = 8, 9, 10, ..., 31)

fprs: 外部硬件时钟频率

ERR: 波特率误差

## (4) 接收期间允许的波特率范围

接收期间来自发送端的波特率可允许的误差范围如下所示。

注意事项: 必须确保接收期间波特率误差在允许的误差范围内,可用以下公式计算。



图 14-12 接收期间允许的波特率范围

如图 14-12 所示,当检测到起始位后,接收数据的锁存时序由波特率发生器控制寄存器 0(BRGC0)设置的计数器来确定。如果数据的最后一位(停止位)满足该锁存时序,则该数据可被正确接收。假定接收数据为 11 位,各项理论值计算如下。

 $FL = (Brate)^{-1}$ 

 Brate:
 UART0 的波特率

 k:
 BRGC0 设置的值

 FL:
 1 位数据宽度

 锁存时序的极限值: 2 个时钟

可允许的最小数据帧宽度: 
$$FLmin = 11 \times FL - \frac{k-2}{2k} \times FL = \frac{21k+2}{2k} FL$$

因此在发送端设定的可接收的最大波特率如下所示。

BRmax = 
$$(FLmin/11)^{-1}$$
 =  $\frac{22k}{21k + 2}$  Brate

同样, 可计算允许的最大数据帧宽度

$$\frac{10}{11} \times FLmax = 11 \times FL - \frac{k+2}{2 \times k} \times FL = \frac{21k-2}{2 \times k} FL$$

$$FLmax = \frac{21k - 2}{20k} FL \times 11$$

因此在发送端设定的可接收的最小波特率如下所示。

$$BRmin = (FLmax/11)^{-1} = \frac{20k}{21k - 2} Brate$$

可通过上述最小和最大波特率公式计算在 UARTO 与发送端之间允许的波特率误差,如下所示。

|         | 农 14-0 况价的收入收价化处 |            |  |  |  |  |  |  |  |
|---------|------------------|------------|--|--|--|--|--|--|--|
| 分频比 (k) | 允许的最大波特率误差       | 允许的最小波特率误差 |  |  |  |  |  |  |  |
| 8       | +3.53%           | -3.61%     |  |  |  |  |  |  |  |
| 16      | +4.14%           | -4.19%     |  |  |  |  |  |  |  |
| 24      | +4.34%           | -4.38%     |  |  |  |  |  |  |  |
| 31      | +4.44%           | -4.47%     |  |  |  |  |  |  |  |

表 14-6 允许的最大/最小波特率误差

**备注:** 1. 接收时允许的误差与每帧的位数、输入时钟频率和分频比(k)有关。输入时钟频率和分频比(k)越高,允许的误差就越大。

2. k: BRGC0 设置的值。

## 第十五章 串行接口 UART6

#### 15.1 串行接口 UART6 的功能

串行接口 UART6 有以下两种模式。

## (1) 操作停止模式

在不进行串行通信时可采用此模式,以降低功耗。 需要了解详细信息,可参见 **15.4.1 操作停止模式**。

#### (2) 异步串行接口(UART) 模式

该模式支持 LIN(局部互联网)-总线。该模式的功能概括如下。

需要了解详细信息,可参见 15.4.2 异步串行接口(UART)模式 和 15.4.3 专用波特率发生器。

- 最大传输率: 312.5 kbps
  - 双引脚配置 TxD6: 发送数据输出引脚 RxD6: 接收数据输入引脚
  - 可选择通信数据的数据宽度为7或8位。
  - 专用内置8位波特率发生器允许设置任意大小的波特率。
  - 可分别执行发送和接收操作(全双工操作)。
  - 可选 MSB-first 或 LSB-first 通信。
  - 反向发送操作
  - 同步中断区域发送长度为 13~20位
  - 可规定多于 11 位的同步中断区域接收(提供 SBF 接收标志位)。

# 注意事项: 1. TxD6 输出反向操作仅在发送端进行而不在接收端进行。为了能够使用该功能,接收端应准备好接收已反向的数据。

- 2. 如果串行接口 UART6 使用的时钟未被停止(例如,处于 HALT 模式下),则继续正常操作。如果串行接口 UART6 使用的时钟已被停止(例如,处于 STOP 模式下),则寄存器停止操作,并且在时钟停止之前及时保存数据。TXD6 引脚也在时钟停止之前立即保存数据并输出。但在时钟恢复使用后正常操作不能得到保证。因此必须复位电路,使 POWER6 = 0、RXE6 = 0、TXE6 = 0。
- 3. 设置 POWER6 = 1 然后设置 TXE6 = 1 (发送)或 RXE6 = 1 (接收) , 以启动通信。
- 4. 通过基本时钟(fxclke)(由 CKSR6 设置)对 TXE6 与 RXE6 进行同步。若要再次允许发送或接收,必须 在 TXE6 或 RXE6 清零(0)后至少两个基本时钟时将 TXE6 或 RXE6 设置为 1。如果在两个基本时钟 内设置 TXE6 或 RXE6,则发送电路或接收电路可能不被初始化。
- 5. 在设置 TXE6 = 1 后至少经历一个基本时钟(fxclk6)再为 TXB6 设置发送数据。
- 6. 如果连续发送数据,从停止位到下一个起始位的通信时序将延长两个宏操作时钟。但这不会影响到通信结果,因为接收端会在检测到起始位时对时序初始化。如果 UART6 用于 LIN 模式,则不能使用连续发送功能。

**备注:** LIN 表示局部互联网,是一个低速(1~20 kbps)串行通信协议,可用于降低网络费用。

LIN 是一种单主设备(single-master)通信方式,一个主设备上最多可以连接 15 个从设备。

LIN 的从设备用于控制开关、制动器和传感器,这些设备通过 LIN 网与 LIN 主设备相连。

通常, LIN 主设备与一个网络, 如 CAN(控制器局域网 Controller Area Network)相连。

此外, LIN 总线采用单线方式,通过收发器(符合 ISO9141)与各节点相连。

在 LIN 协议中,主设备发送带有波特率信息的一帧数据,从设备接收数据并校正波特率误差。因此当从设备端的波特率误差在 ±15%范围内时,可以进行通信。

图 15-1 和 15-2 概括了 LIN 的发送和接收操作。

## 图 15-1 LIN 发送操作



- 注: 1. 在8位发送模式中,可通过发送80H替代唤醒信号帧。
  - **2.** 使用硬件输出同步中断区。可通过异步串行接口控制寄存器 6(ASICL6)的第 4 ~2 位(SBL62 ~ SBL60) 设置输出宽度(等于位长度)(参见 **15.4.2 (2) (h) SBF 发送**)。
  - 3. 每次发送完成时输出 INTST6。在发送 SBF 时也输出 INTST6。

**备注:** 区域之间的间隔由软件控制。

#### 图 15-2 LIN 接收操作



接收处理过程如下。

- <1> 在引脚的边沿处检测唤醒信号,允许使用 UART6,并设置 SBF 接收模式。
- <2> 当检测到停止位时才停止接收操作。在检测到至少 11 位低电平数据的 SBF 时,认为 SBF 已被正确接收,并输出一个中断信号。在检测到少于 11 位低电平数据的 SBF 时,认为出现 SBF 接收错误。此时不输出中断信号,而是恢复 SBF 接收模式。
- <3> 如果 SBF 被正确接收,将输出一个中断信号。用这个 SBF 接收完成中断服务来启动 16 位定时器/事件计数器 00 并测量同步区的位长度(脉冲宽度)(参见 7.4.8 脉冲宽度测量操作)。禁止检测 OVE6、PE6 和 FE6 错误,不进行 UART 通信的错误检测,也不执行移位寄存器和 RXB6 之间的数据传送。移位寄存器中保存复位值 FEH
- <4> 根据同步区的位长度计算波特率误差,在 SBF 接收后禁止使用 UART6,然后对波特率发生器控制寄存器 6(BRGC6)重新设置。
- <5> 用软件区分校验和区。在接收到校验和区后通过软件对 UART6 进行初始化,并再次设置 SBF 接收模式。

图 15-3 显示了 LIN 接收操作的端口配置。

通过检测外部中断信号(INTP0)脉冲沿,接收从 LIN 主设备发出的唤醒信号。根据 16 位定时器/事件计数器 00 的外部事件捕捉操作来测量 LIN 主设备发送的同步区的位长度,并计算波特率误差。

不进行外部连接 RxD6 和 INTP0/TI000,而由端口输入切换控制(ISC0/ISC1)可将接收端口的(RxD6)的输入源输入给外部中断(INTP0)和 16 位定时器/事件计数器 00。



图 15-3 LIN 接收操作的端口配置

备注: ISC0, ISC1: 输入切换控制寄存器(ISC)的第0和1位(参见图15-11)

以下是 LIN 通信中用到的外部功能。

<用到的外部功能>

- 外部中断(INTP0): 唤醒信号检测 用途: 检测唤醒信号的脉冲沿和通信的开始。
- 16 位定时器/事件计数器 00(TI000);波特率误差检测 用途:通过检测同步区(SF)的位长度并按位分频,来检测波特率误差(在捕捉模式下测量 TI000 输入脉冲的间隔)。
- 串行接口 UART6

## 15.2 串行接口 UART6 的配置

串行接口 UART6 包括以下硬件。

表 15-1 串行接口 UART6 的配置

| 项目    | 配置                                                                                                                                                                                                           |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 寄存器   | 接收缓冲寄存器 6 (RXB6)<br>接收移位寄存器 6 (RXS6)<br>发送缓冲寄存器 6 (TXB6)<br>发送移位寄存器 6 (TXS6)                                                                                                                                 |
| 控制寄存器 | 异步串行接口操作模式寄存器 6 (ASIM6)<br>异步串行接口接收错误状态寄存器 6 (ASIS6)<br>异步串行接口发送状态寄存器 6 (ASIF6)<br>时钟选择寄存器 6 (CKSR6)<br>波特率发生器控制寄存器 6 (BRGC6)<br>异步串行接口控制寄存器 6 (ASICL6)<br>输入切换控制寄存器(ISC)<br>端口模式寄存器 1 (PM1)<br>端口寄存器 1 (P1) |



注: 使用输入切换控制寄存器 (ISC)进行选择。

发送单元

图 15-4 串行接口 UART6 的框图

#### (1) 接收缓冲寄存器 6 (RXB6)

该 8 位寄存器用于存储由接收移位寄存器(RXS6)移位的并行数据。

每接收到 1 字节的数据,新的接收数据就从 RXS6 传送到该寄存器中。如果数据宽度被设定为 7 位,则按如下方式 发送数据。

- 在 LSB-first 接收模式下,将接收到的数据传送到 RXB6 的 0~6 位,而 MSB 位恒为 0。
- 在 MSB-first 接收模式下,将接收到的数据传送到 RXB6 的 1~7 位,而 LSB 位恒为 0。

如果出现溢出错误(OVE6),则不把接收数据传送到RXB6中。

可由 8 位存储器操作指令读取 RXB6 的内容。不能将数据写入该寄存器中。

复位信号产生将该寄存器设置为 FFH。

## (2) 接收移位寄存器 6 (RXS6)

该寄存器将输入到 RxD6 引脚的串行数据转换成并行数据。

程序不能直接使用 RXS6。

#### (3) 发送缓冲寄存器 6 (TXB6)

该寄存器用于设置发送数据。当数据写入TXB6时开始发送。可由8位存储器操作指令对TXB6进行读或写操作。 复位信号产生将该寄存器设置为FFH。

注意事项: 1. 当异步串行接口发送状态寄存器 6(ASIF6)的第 1 位(TXBF6)=1 时不要对 TXB6 进行写操作。

- 2. 在通信过程中(当异步串行接口操作模式寄存器 6(ASIM6)的第7位(POWER6)和第6位(TXE6)均为 1,或 ASIM6的第7位(POWER6)和第5位(RXE6)均为1),不要通过软件刷新(写入相同值)TXB6。
- 3. 在设置 TXE6 = 1 后,至少经过一个基本时钟(fxclk6),将发送数据写入 TXB6。

#### (4) 发送移位寄存器 6 (TXS6)

该寄存器将 TXB6 中要传送的数据作为串行数据从 TxD6 移出。在第 1 次发送过程中,当数据写入 TXB6 后立即被传送。或者在持续发送过程中,当发出 1 帧数据后,INTST6 中断产生之前数据立即被传送。利用基本时钟的下降沿从 TxD6 引脚传送来自 TXB6 的数据。

程序不能直接对 TXS6 操作。

## 15.3 控制串行接口 UART6 的寄存器

串行接口 UART6 由以下 9个寄存器控制。

- 异步串行接口操作模式寄存器 6 (ASIM6)
- 异步串行接口接收错误状态寄存器 6 (ASIS6)
- 异步串行接口发送状态寄存器 6 (ASIF6)
- 时钟选择寄存器 6 (CKSR6)
- 波特率发生器控制寄存器 6 (BRGC6)
- 异步串行接口控制寄存器 6 (ASICL6)
- 输入切换控制寄存器(ISC)
- 端口模式寄存器 1 (PM1)
- 端口寄存器 1 (P1)

## (1) 异步串行接口操作模式寄存器 6 (ASIM6)

该8位寄存器用于控制串行接口 UART6 的串行通信。可由1位或8位存储器操作指令设置该寄存器。 复位信号产生将该寄存器设置为01H。

**备注:** 在通信过程中(当异步串行接口操作模式寄存器 6(ASIM6)的第7位(POWER6)和第6位(TXE6)均为1,或 ASIM6的第7位(POWER6)和第5位(RXE6)均为1),可以通过软件刷新(写入相同值)ASIM6。

#### 图 15-5 异步串行接口操作模式寄存器 6 (ASIM6)的格式 (1/2)

地址: FF50H 复位后: 01H R/W

| 符号    | <7>    | <6>  | <5>  | 4    | 3    | 2   | 1   | 0     |
|-------|--------|------|------|------|------|-----|-----|-------|
| ASIM6 | POWER6 | TXE6 | RXE6 | PS61 | PS60 | CL6 | SL6 | ISRM6 |

| POWER6           | 允许/禁止内部操作时钟的操作                       |
|------------------|--------------------------------------|
| O <sup>注 1</sup> | 禁止内部操作时钟的操作(时钟恒为低电平)并对内部电路进行异步复位 建2。 |
| 1                | 允许内部操作时钟的操作                          |

| TXE6 | 允许/禁止发送        |
|------|----------------|
| 0    | 禁止发送(同步复位发送电路) |
| 1    | 允许发送           |

| RXE6 | 允许/禁止接收        |
|------|----------------|
| 0    | 禁止接收(同步复位接收电路) |
| 1    | 允许接收           |

注: 1. 发送期间当 POWER6 = 0 时, TxD6 引脚的输出变为高电平, 而来自 RxD6 引脚的输入恒为高电平。

2. 对异步串行接口接收错误状态寄存器 6(ASIS6)、异步串行接口发送状态寄存器 6(ASIF6)、异步串行接口控制寄存器 6(ASICL6)的第7位(SBRF6)和第6位(SBRT6),以及接收缓冲寄存器 6(RXB6)进行复位。

## 图 15-5 异步串行接口操作模式寄存器 6 (ASIM6)的格式 (2/2)

| PS61 | PS60 | 发送操作   | 接收操作                |
|------|------|--------|---------------------|
| 0    | 0    | 不输出校验位 | 无校验接收               |
| 0    | 1    | 输出零校验  | 按零校验接收 <sup>推</sup> |
| 1    | 0    | 输出奇校验  | 按奇校验判断              |
| 1    | 1    | 输出偶校验  | 按偶校验判断              |

| CL6 | 指定发送/接收数据的字符宽度 |
|-----|----------------|
| 0   | 数据的字符宽度 = 7位   |
| 1   | 数据的字符宽度 = 8 位  |

| SL6 | 指定发送数据停止位的个数 |
|-----|--------------|
| 0   | 停止位的个数 = 1   |
| 1   | 停止位的个数 = 2   |

| ISRM6 | 允许/禁止出错时接收完成中断的产生             |  |  |  |  |  |  |  |  |
|-------|-------------------------------|--|--|--|--|--|--|--|--|
| 0     | 出错时产生"INTSRE6"(此时,不产生 INTSR6) |  |  |  |  |  |  |  |  |
| 1     | 出错时产生"INTSR6"(此时,不产生 INTSRE6) |  |  |  |  |  |  |  |  |

注: 如果选择"按零校验接收",则无法判断校验。因此不要设置异步串行接口接收错误状态寄存器 0(ASIS6)的 第 2 位(PE6),这样也不会产生出错中断。

- 注意事项: 1. 启动发送操作时,对 POWER6 置 1,然后对 TXE6 置 1。停止发送操作时,先将 TXE6 清零,然后将 POWER6 清零。
  - 2. 启动接收操作时,对 POWER6 置 1,然后对 RXE6 置 1。停止接收操作时,先将 RXE6 清零,然后 将 POWER6 清零。
  - 3. 当 RxD6 引脚输入为高电平时,先对 POWER6 置 1, 再对 RXE6 置 1。当输入为低电平 POWER6 置 1, RXE6 置 1 时,启动接收操作。
  - 4. 通过基本时钟(fxclke)(由 CKSR6 设置)对 TXE6 与 RXE6 进行同步。 若要再次允许发送或接收,必须 在 TXE6 或 RXE6 清零(0)后至少两个基本时钟时将 TXE6 或 RXE6 设置为 1。如果在两个基本时钟内 设置 TXE6 或 RXE6,则发送电路或接收电路可能不被初始化。
  - 5. 设置 TXE6 = 1 后,至少经过一个基本时钟(fxclke),将发送数据写入 TXB6。
  - 6. 在对 PS61、PS60 和 CL6 位重写之前,先将 TXE6 和 RXE6 位清零。
  - 7. 工作在 LIN 模式时, PS61 与 PS60 恒为 0。
  - 8. 在重写 SL6 位时,必须确保 TXE6 = 0。总是以"停止位的个数=1"的格式执行接收操作,因此接收不会受到 SL6 设置值的影响。
  - 9. 当重写 ISRM6 时,RXE6 必须为 0。

## (2) 异步串行接口接收错误状态寄存器 6 (ASIS6)

该寄存器用于指示串行接口 UART6 的接收操作完成时出现的错误状态,包括 3 个出错标志位(PE6,FE6,OVE6)。

可由8位存储器操作指令对该寄存器进行只读操作。

如果 ASIM6 的第 5 位(RXE6)或第 7 位(POWER6) = 0,则复位信号产生将该寄存器设置为 00H。读取该寄存器的值为 00H。如果产生接收错误,读取 ASIS6 再读取接收缓冲寄存器 6 (RXB6),可将出错标志清零。

#### 图 15-6 异步串行接口接收错误状态寄存器 6 (ASIS6)的格式

地址: FF53H 复位后: 00H R

| 符号    | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    |
|-------|---|---|---|---|---|-----|-----|------|
| ASIS6 | 0 | 0 | 0 | 0 | 0 | PE6 | FE6 | OVE6 |

| PE6 | 指示校验错误的状态标志位                          |  |  |  |  |  |  |  |
|-----|---------------------------------------|--|--|--|--|--|--|--|
| 0   | 如果 POWER6 = 0 且 RXE6 = 0,或者如果读取 ASIS6 |  |  |  |  |  |  |  |
| 1   | 如果发送数据的校验位与接收完成时的校验位不匹配               |  |  |  |  |  |  |  |

| FE6 | 指示帧错误的状态标志位                           |  |  |  |  |  |  |  |  |
|-----|---------------------------------------|--|--|--|--|--|--|--|--|
| 0   | □果 POWER6 = 0 且 RXE6 = 0、或者如果读取 ASIS6 |  |  |  |  |  |  |  |  |
| 1   | 如果接收完成时未检测到停止位                        |  |  |  |  |  |  |  |  |

| OVE6 | 指示溢出错误的状态标志位                          |  |  |  |  |  |  |  |  |
|------|---------------------------------------|--|--|--|--|--|--|--|--|
| 0    | □果 POWER6 = 0 且 RXE6 = 0、或 ASIS6 被读取  |  |  |  |  |  |  |  |  |
| 1    | 如果将接收数据存于 RXB6 寄存器中且在读取该数据前下一个接收操作已完成 |  |  |  |  |  |  |  |  |

# 注意事项: 1. 根据异步串行接口操作模式寄存器 6(ASIM6)的 PS61 和 PS60 位的内容的不同,对 PE6 位的操作也有所不同。

- 2. 无论停止位的个数是多少,只将接收数据的第1位作为停止位进行检测。
- 3. 如果出现溢出错误,则下一个接收数据不写入接收缓冲寄存器 6(RXB6)中而是被忽略。
- **4.** 如果从 ASIS6 读取数据,会产生一个等待周期。当 CPU 采用子系统时钟而停止外部硬件时钟操作时,不要从 ASIS6 读取数据。需要了解详细信息,可参见第三十二章 等待注意事项。

## (3) 异步串行接口发送状态寄存器 6 (ASIF6)

该寄存器指示串行接口 UART6 的发送状态,包括两个状态标志位(TXBF6 和 TXSF6)。

当数据从 TXB6 传送到 TXS6 中后,通过将下一个发送数据写入 TXB6,使得发送能够连续进行而不被中断,即便是在中断产生期间也不受影响。

可由8位存储器操作指令对该寄存器进行只读操作。

如果 ASIM6 的第7位(POWER6)或第6位(TXE6)置0,则复位信号产生将该寄存器设置为00H。

#### 图 15-7 异步串行接口发送状态寄存器 6 (ASIF6)的格式

地址: FF55H 复位后: 00H R

| 符号    | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     |
|-------|---|---|---|---|---|---|-------|-------|
| ASIF6 | 0 | 0 | 0 | 0 | 0 | 0 | TXBF6 | TXSF6 |

| TXBF6 | 发送缓冲数据标志位                                           |  |  |  |  |  |  |  |
|-------|-----------------------------------------------------|--|--|--|--|--|--|--|
| 0     | 如果 POWER6 = 0 或 TXE6 = 0, 或如果数据被传送到发送移位寄存器 6(TXS6)中 |  |  |  |  |  |  |  |
| 1     | 当数据被写入发送缓冲寄存器 6(TXB6)中(如果数据已在 TXB6 中)               |  |  |  |  |  |  |  |

| TXSF6 | 发送移位寄存器数据标志位                                                |
|-------|-------------------------------------------------------------|
| 0     | 如果 POWER6 = 0 或 TXE6 = 0, 或如果发送完成后下一个数据没有从发送缓冲寄存器 6(TXB6)发出 |
| 1     | 如果数据从发送缓冲寄存器 6(TXB6)发出(如果数据仍在发送过程中)                         |

- 注意事项: 1. 为了能够连续发送数据,应将第一个发送的数据(第一个字节)写入 TXB6 中。之后,检查 TXBF6 标志 位,必须为 "0"。如果正确,将下一个发送数据(第二个字节)写入 TXB6 中。如果 TXBF6 标志为 "1"时将数据写入 TXB6,则无法保证发送数据的正确性。
  - 2. 如果要在连续发送结束时初始化发送单元,则在产生发送完成中断后必须检查 TXSF6 标志位,应为 "0"。然后执行初始化操作。如果 TXSF6 标志为 "1"时执行初始化操作,则无法保证发送数据的 正确性。

## (4) 时钟选择寄存器 6 (CKSR6)

该寄存器用于选择串行接口 UART6 的基本时钟。

可由8位存储器操作指令设置CKSR6。

复位信号产生将该寄存器清零(00H)。

**备注:** 通信过程中(当异步串行接口操作模式寄存器 6(ASIM6)的第7位(POWER6)和第6位(TXE6)均为1,或 ASIM6的第7位(POWER6)和第5位(RXE6)均为1),可由软件刷新(写入相同值)CKSR6。

## 图 15-8 时钟选择寄存器 6 (CKSR6)的格式

地址: FF56H 复位后: 00H R/W

符号 7 6 3 2 1 0 CKSR6 0 0 0 0 TPS63 TPS62 TPS61 TPS60

| TPS63 | TPS62 | TPS61 | TPS60 |                      | 基本时钟(fхське) 的选择         |                          |                           |                           |  |
|-------|-------|-------|-------|----------------------|--------------------------|--------------------------|---------------------------|---------------------------|--|
|       |       |       |       |                      | f <sub>PRS</sub> = 2 MHz | f <sub>PRS</sub> = 5 MHz | f <sub>PRS</sub> = 10 MHz | f <sub>PRS</sub> = 20 MHz |  |
| 0     | 0     | 0     | 0     | fprs                 | 2 MHz                    | 5 MHz                    | 10 MHz                    | 20 MHz                    |  |
| 0     | 0     | 0     | 1     | fprs/2               | 1 MHz                    | 2.5 MHz                  | 5 MHz                     | 10 MHz                    |  |
| 0     | 0     | 1     | 0     | fprs/2 <sup>2</sup>  | 500 kHz                  | 1.25 MHz                 | 2.5 MHz                   | 5 MHz                     |  |
| 0     | 0     | 1     | 1     | fprs/2 <sup>3</sup>  | 250 kHz                  | 625 kHz                  | 1.25 MHz                  | 2.5 MHz                   |  |
| 0     | 1     | 0     | 0     | fprs/24              | 125 kHz                  | 312.5 kHz                | 625 kHz                   | 1.25 MHz                  |  |
| 0     | 1     | 0     | 1     | fprs/2 <sup>5</sup>  | 62.5 kHz                 | 156.25 kHz               | 312.5 kHz                 | 625 kHz                   |  |
| 0     | 1     | 1     | 0     | fprs/2 <sup>6</sup>  | 31.25 kHz                | 78.13 kHz                | 156.25 kHz                | 312.5 kHz                 |  |
| 0     | 1     | 1     | 1     | fprs/2 <sup>7</sup>  | 15.625 kHz               | 39.06 kHz                | 78.13 kHz                 | 156.25 kHz                |  |
| 1     | 0     | 0     | 0     | fprs/2 <sup>8</sup>  | 7.813 kHz                | 19.53 kHz                | 39.06 kHz                 | 78.13 kHz                 |  |
| 1     | 0     | 0     | 1     | fprs/29              | 3.906 kHz                | 9.77 kHz                 | 19.53 kHz                 | 39.06 kHz                 |  |
| 1     | 0     | 1     | 0     | fprs/2 <sup>10</sup> | 1.953 kHz                | 4.88 kHz                 | 9.77 kHz                  | 19.53 kHz                 |  |
| 1     | 0     | 1     | 1     | TM50 输出 <sup>推</sup> |                          |                          |                           |                           |  |
|       | 其它    | 情况    |       | 禁止设置                 |                          |                          |                           |                           |  |

注: 选择 TM50 输出作为基本时钟时,应注意以下几点。

- TM50 与 CR50 相等(TMC506 = 0)时产生清零并启动的模式(TMC506 = 0) 先启动 8 位定时器/事件计数器 50, 然后允许定时器 F/F 反转操作(TMC501 = 1)。
- PWM 模式 (TMC506 = 1)

先启动 8 位定时器/事件计数器 50, 然后设置计数时钟, 使占空比 = 50%。

不论何种模式,都不必将 TO50 作为定时器输出引脚。

注意事项: 在重写 TPS63 ~ TPS60 位时, 必须确保 POWER6 = 0。

**备注: 1.** fprs: 外部硬件时钟频率

2. TMC506: 8 位定时器模式控制寄存器 50(TMC50)的第 6 位

TMC501: TMC50 的第 1 位

## (5) 波特率发生器控制寄存器 6 (BRGC6)

该寄存器用于设置串行接口 UART6 的 8 位计数器的分频值。可由 8 位存储器操作指令设置 BRGC6。 复位信号产生将该寄存器设置为 FFH。

**备注:** 通信过程中(当异步串行接口操作模式寄存器 6(ASIM6)的第7位(POWER6)和第6位(TXE6)均为1,或 ASIM6的第7位(POWER6)和第5位(RXE6)均为1),可由软件刷新(写入相同值)BRGC6。

## 图 15-9 波特率发生器控制寄存器 6 (BRGC6)的格式

地址: FF57H 复位后: FFH R/W

符号 7 6 5 4 3 2 1 0 BRGC6 MDL67 MDL66 MDL65 MDL64 MDL63 MDL62 MDL61 MDL60

| MDL67 | MDL66 | MDL65 | MDL64 | MDL63 | MDL62 | MDL61 | MDL60 | k   | 8位计数器输出时钟选择 |
|-------|-------|-------|-------|-------|-------|-------|-------|-----|-------------|
| 0     | 0     | 0     | 0     | 0     | ×     | ×     | ×     | ×   | 禁止设置        |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 8   | fxclk6/8    |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 9   | fxclk6/9    |
| 0     | 0     | 0     | 0     | 1     | 0     | 1     | 0     | 10  | fxclk6/10   |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •           |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •           |
| •     | •     | •     | •     | •     | •     | •     | •     | •   | •           |
|       |       | •     |       |       |       |       |       | •   | •           |
| 1     | 1     | 1     | 1     | 1     | 1     | 0     | 0     | 252 | fxclк6/252  |
| 1     | 1     | 1     | 1     | 1     | 1     | 0     | 1     | 253 | fxclк6/253  |
| 1     | 1     | 1     | 1     | 1     | 1     | 1     | 0     | 254 | fxclk6/254  |
| 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 255 | fxclк6/255  |

注意事项: 1. 在重写 MDL67 ~ MDL60 位时,必须确保 ASIM0 的第 6 位(TXE6)和第 5 位(RXE6) = 0。

2. 波特率为8位计数器输出时钟的1/2。

**备注:** 1. fxclk6: 根据 CKSR6 寄存器的 TPS63 ~ TPS60 位选择基本时钟的频率

**2.** k: 由 MDL67 ∼ MDL60 位设置的值 (k = 8, 9, 10, ..., 255)

3. x: 不必考虑

## (6) 异步串行接口控制寄存器 6 (ASICL6)

该寄存器用于控制串行接口 UART6 的串行通信操作。可由 1 位或 8 位存储器操作指令设置 ASICL6。 复位信号产生将该寄存器设置为 16H。

注意事项: 通信过程中(当异步串行接口操作模式寄存器 6(ASIM6)的第 7 位(POWER6)和第 6 位(TXE6)均为 1,或 ASIM6 的第 7 位(POWER6)和第 5 位(RXE6)均为 1),可由软件刷新(写入相同值)ASICL6。但是,由于可能会重新触发 SBF 接收和 SBF 发送,因此在 SBF 接收期间(SBRT6 = 1)或 SBF 发送期间通过刷新操作不要将 SBRT6 与 SBTT6 都设置为 1(直到由于 SBTT6=1 而产生 INTST6 为止)。

图 15-10 异步串行接口控制寄存器 6 (ASICL6) 的格式(1/2)

地址: FF58H 复位后: 16H R/W \*\* 符号 <7> 2 <6> 5 3 0 ASICL6 SBTT6 SBL61 SBL60 SBRF6 SBRT6 SBL62 DIR6 TXDLV6

| SBRF6 | SBF 接收状态标志                               |
|-------|------------------------------------------|
| 0     | 如果 POWER6 = 0 且 RXE6 = 0, 或者如果 SBF 已正确接收 |
| 1     | SBF 接收操作正在进行中                            |

| SBRT6 | SBF 接收触发 |
|-------|----------|
| 0     | _        |
| 1     | SBF 接收触发 |

| SBTT6 | SBF 发送触发 |
|-------|----------|
| 0     | -        |
| 1     | SBF 发送触发 |

注: 第7位是只读的。

图 15-10 异步串行接口控制寄存器 6 (ASICL6)的格式 (2/2)

| SBL62 | SBL61 | SBL60 | SBF 发送输出宽度控制   |
|-------|-------|-------|----------------|
| 1     | 0     | 1     | SBF 输出宽度: 13 位 |
| 1     | 1     | 0     | SBF 输出宽度: 14 位 |
| 1     | 1     | 1     | SBF 输出宽度: 15 位 |
| 0     | 0     | 0     | SBF 输出宽度: 16 位 |
| 0     | 0     | 1     | SBF 输出宽度: 17 位 |
| 0     | 1     | 0     | SBF 输出宽度: 18 位 |
| 0     | 1     | 1     | SBF 输出宽度: 19 位 |
| 1     | 0     | 0     | SBF 输出宽度: 20 位 |

| DIR6 | 首位说明 |
|------|------|
| 0    | MSB  |
| 1    | LSB  |

| TXDLV6 | 允许/禁止反向 TxD6 输出 |
|--------|-----------------|
| 0      | TxD6 正常输出       |
| 1      | TxD6 反向输出       |

注意事项: 1. 如果出现 SBF 接收错误,则返回到 SBF 接收模式,并保持 SBRF6 标志位状态(1)不变。

- 2. 在设置 SBRT6 之前,必须确保 ASIM6 的第 7 位(POWER6)和第 5 位(RXE6)为 1。在设置 SBRT6=1 后 SBF 接收完成(产生中断请求信号之前)之前不要将 SBRT6 清零。
- 3. SBRT6 的读取值恒为 0。在 SBF 正确接收后 SBRT6 自动清零。
- 4. 在设置 SBTT6=1 之前,必须确保 ASIM6 的第 7 位(POWER6)和第 6 位(TXE6)为 1。在设置 SBTT6=1 之后 SBF 接收完成(产生中断请求信号之前)之前不要将 SBTT6 清零。
- 5. SBTT6 的读取值恒为 0。并在 SBF 发送结束后自动清零。
- 6. 在接收期间不要设置 SBRT6=1, 而在发送期间不要设置 SBTT6=1。
- 7. 在重写 DIR6 和 TXDLV6 之前,应对 TXE6 和 RXE6 清零。

\*

## (7) 输入切换控制寄存器(ISC)

输入切换控制寄存器(ISC)在 LIN(Local Interconnect Network 本地互联网络)接收期间用于接收从主设备发送的状态信号。

★ 当 ISC0 与 ISC1=1 时,选择 P14/RxD6 引脚的信号输入作为 INTP0 与 TI000 的输入源。

可由 1 位或 8 位存储器操作指令设置该寄存器。

复位信号产生将该寄存器清零(00H)。

## 图 15-11 输入切换控制寄存器(ISC)的格式

地址: FF4FH 复位后: 00H R/W

| 符号  | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|-----|---|---|---|---|---|---|------|------|
| ISC | 0 | 0 | 0 | 0 | 0 | 0 | ISC1 | ISC0 |

| ISC1 | TI000 输入源的选择 |
|------|--------------|
| 0    | TI000 (P00)  |
| 1    | RxD6 (P14)   |

| ISC0 | INTPO 输入源的选择 |
|------|--------------|
| 0    | INTP0 (P120) |
| 1    | RxD6 (P14)   |

#### (8) 端口模式寄存器 1 (PM1)

该寄存器可以按位设置端口1的输入/输出模式。

当 P13/TxD6 引脚用于串行接口数据输出时,将 PM13 清零且 P13 的输出锁存器的值设置为 1。

当 P14/RxD6 引脚用于串行接口数据输入时,将 PM14 置 1。此时 P14 的输出锁存器的值= 0 或 1。

可由 1 位或 8 位存储器操作指令设置 PM1。

复位信号产生将该寄存器设置为 FFH。

#### 图 15-12 端口模式寄存器 1 (PM1)的格式

地址: FF21H 复位后: FFH R/W

符号 7 6 5 3 2 1 0 4 PM1 PM17 PM16 PM15 PM14 PM13 PM12 PM11 PM10

| PM1n | n P1n 引脚 I/O 模式选择 (n = 0~7) |  |
|------|-----------------------------|--|
| 0    | 输出模式 (输出缓冲器打开)              |  |
| 1    | 输入模式 (输出缓冲器关闭)              |  |

## 15.4 串行接口 UART6 的操作

串行接口 UART6 有以下两种模式。

- 操作停止模式
- 异步串行接口(UART) 模式

#### 15.4.1 操作停止模式

在此模式下,不能进行串行通信,因此,可降低功耗。此外,引脚可作为一般的端口引脚使用。通过将 ASIM6 的第7、6和5位(POWER6、TXE6和RXE6)清零,可设置操作停止模式。

#### (1) 使用的寄存器

由异步串行接口操作模式寄存器 6(ASIM6)设置操作停止模式。

可由 1 位或 8 位存储器操作指令设置 ASIM6。

复位信号产生将该寄存器设置为 01H。

地址: FF50H 复位后: 01H R/W

| 符号    | <7>    | <6>  | <5>  | 4    | 3    | 2   | 1   | 0     |
|-------|--------|------|------|------|------|-----|-----|-------|
| ASIM6 | POWER6 | TXE6 | RXE6 | PS61 | PS60 | CL6 | SL6 | ISRM6 |

| POWER6            | 允许/禁止内部操作时钟的操作                     |
|-------------------|------------------------------------|
| O <sup>推: 1</sup> | 禁止内部操作时钟的操作(时钟恒为低电平)且对内部电路进行异步复位推2 |

| TX | KE6 | 允许/禁止发送         |
|----|-----|-----------------|
|    | 0   | 禁止发送 (同步复位发送电路) |

| RXE6 | 允许/禁止接收         |  |  |  |
|------|-----------------|--|--|--|
| 0    | 禁止接收 (同步复位接收电路) |  |  |  |

注: 1. 发送期间当 POWER6 = 0 时, TxD6 的输出变成高电平而来自 RxD0 引脚的输入恒为高电平。

2. 对异步串行接口接收错误状态寄存器 6(ASIS6)、异步串行接口发送状态寄存器 6(ASIF6)、异步串行接口控制寄存器(ASICL6)的第7位(SBRF6)和第6位(SBRT6)和接收缓冲寄存器 6(RXB6)进行复位。

注意事项: TXE6 和 RXE6 清零后再对 POWER6 清零,可设置操作停止模式。 如果要启动发送或接收操作,则先设置 POWER6=1,然后设置 TXE6=1 或 RXE6=1。

备注: 如果将 RxD6/P14 和 TxD6/P13 作为通用端口引脚使用,可参见第五章 端口功能。

#### 15.4.2 异步串行接口(UART)模式

此模式下,在传送了起始位后,紧接着发送/接收 1 字节数据,然后可执行全双工操作。可使用专用 UART 波特率发生器,这样通信选择的波特率范围较大。

## (1) 使用的寄存器

- 异步串行接口操作模式寄存器 6 (ASIM6)
- 异步串行接口接收错误状态寄存器 6 (ASIS6)
- 异步串行接口发送状态寄存器 6 (ASIF6)
- 时钟选择寄存器 6 (CKSR6)
- 波特率发生器控制寄存器 6 (BRGC6)
- 异步串行接口控制寄存器 6 (ASICL6)
- 输入切换控制寄存器(ISC)
- 端口模式寄存器 1 (PM1)
- 端口寄存器 1 (P1)

在 UART 模式中设置操作的基本过程如下。

- <1> 设置 CKSR6 寄存器 (参见图 15-8)
- <2> 设置 BRGC6 寄存器 (参见图 15-9)
- <3> 设置 ASIM6 的 0~4 位 (ISRM6、SL6、CL6、PS60、PS61) (参见 图 15-5)
- <4> 设置 ASICL6 的第 0 和 1 位 (TXDLV6、DIR6) (参见 图 15-10)
- <5> 设置 ASIM6 的第7位 (POWER6) = 1
- <6> 设置 ASIM6 的第 6 位 (TXE6) = 1。 → 允许发送 设置 ASIM6 的第 5 位 (RXE6) = 1。 → 允许接收
- <7> 将数据写入发送缓冲寄存器 6 (TXB6) → 开始发送数据

注意事项: 在设置端口模式寄存器和端口寄存器时, 要考虑与通信另一方的关系。

寄存器设置与引脚之间的关系如下所示。

表 15-2 寄存器设置与引脚之间的关系

| POWER6 | TXE6 | RXE6 | PM13            | P13             | PM14         | P14             | UART6 引脚功能 |          | 功能       |
|--------|------|------|-----------------|-----------------|--------------|-----------------|------------|----------|----------|
|        |      |      |                 |                 |              |                 | 操作         | TxD6/P13 | RxD6/P14 |
| 0      | 0    | 0    | × <b>注</b> :    | × <sup>注:</sup> | × <b>注</b> : | × <sup>注:</sup> | 停止         | P13      | P14      |
| 1      | 0    | 1    | × <sup>注:</sup> | × <sup>注:</sup> | 1            | ×               | 接收         | P13      | RxD6     |
|        | 1    | 0    | 0               | 1               | × <b>注</b> : | × <b>注</b> :    | 发送         | TxD6     | P14      |
|        | 1    | 1    | 0               | 1               | 1            | ×               | 发送/        | TxD6     | RxD6     |
|        |      |      |                 |                 |              |                 | 接收         |          |          |

注:可以用作端口寄存器。

**备注:** x: 不必考虑

POWER6: 异步串行接口操作模式寄存器 6(ASIM6)的第7位

TXE6: ASIM6 的第 6 位 RXE6: ASIM6 的第 5 位 PM1×: 端口模式寄存器 P1×: 端口输出锁存器

## (2) 通信操作

## (a) 正常发送/接收数据的格式和波形示例

图 15-13 和 15-14 为正常发送/接收数据的格式和波形示例。

#### 图 15-13 正常 UART 发送/接收数据的格式

## 1. LSB-first 发送/接收



#### 2. MSB-first 发送/接收



- 一帧数据由以下各位组成。
- 起始位 ... 1 位
- 字符位 ... 7 或 8 位
- 校验位 ... 偶校验、奇校验、零校验或无校验
- 停止位 ... 1 或 2 位

由异步串行接口操作模式寄存器 6(ASIM6)规定一个数据帧中字符位的宽度、校验方式和停止位的宽度。由异步串行接口控制寄存器 6 (ASICL6)的第 1 位(DIR6)规定数据通信方式(LSB-first 或 MSB-first)。由 ASICL6 的第 0 位(TXDLV6)规定 TxD6 引脚输出的是正常数据还是反向数据。

## 图 15-14 正常 UART 发送/接收数据波形示例

1. 数据宽度: 8 位、LSB-first, 校验位: 偶校验, 停止位: 1 位, 通信数据: 55H



2. 数据宽度: 8 位、MSB-first,校验位: 偶校验, 停止位: 1 位, 通信数据: 55H



3. 数据宽度: 8 位、MSB-first, 校验位: 偶校验, 停止位: 1 位, 通信数据: 55H, TxD6 引脚输出反向数据



4. 数据宽度: 7 位、LSB-first, 校验位: 奇校验, 停止位: 2 位, 通信数据: 36H



5. 数据宽度: 8 位、LSB-first, 校验位: 无, 停止位: 1 位, 通信数据: 87H



## (b) 校验方式与操作

校验位用于检测数据通信中的位错误。通常在发送和接收两端可采用相同的校验方式。当采用偶校验和奇校验时,可检测到1位(奇数位)错误。而采用零校验和无校验时,则不能检测到错误。

## 注意事项: 在 LIN 模式下, PS61 与 PS60 恒为 0。

## (i) 偶校验

发送

控制发送数据,包括校验位,使得数据中"1"的个数为偶数。 校验位的取值如下。

如果发送数据有奇数个"1": 1 如果发送数据有偶数个"1": 0

#### 接收

计算接收数据(包括校验位)中"1"的个数。如果"1"的个数为奇数,则产生校验错。

## (ii) 奇校验

发送

控制发送数据,包括校验位,使得数据中"1"的个数为奇数。

如果发送数据有奇数个"1": 0 如果发送数据有偶数个"1": 1

#### 接收

计算接收数据(包括校验位)中"1"的个数。如果"1"的个数为偶数,则产生校验错。

#### (iii) 零校验

无论发送数据为何值,发送时校验位清零。 接收数据时不检测校验位。因此无论校验位为何值,都不会产生校验错。

#### (iv) 无校验

发送数据中没有校验位。

进行接收操作时认为接收数据中没有校验位。因此也不会产生校验错。

## (c) 正常发送

在设置异步串行接口操作模式寄存器 6(ASIM6)的第 7 位(POWER6)=1 然后设置 ASIM6 的第 6 位(TXE6)=1 时,则允许发送。将待发送的数据写入发送缓冲寄存器 6(TXB6)中,可启动发送操作。起始位、校验位和停止位会自动被添加到数据中。

启动发送操作时,TXB6 中的数据被传送到发送移位寄存器 6(TXS6)中,然后数据依次从 TXS6 被输出到 TxD6 引脚。当发送结束时,由 ASIM6 设置的校验位和停止位被添加到数据中,并产生发送完成中断请求 (INTST6)。

当下一个发送数据写入 TXB6 时,发送操作才结束。

图 15-15 显示了发送完成中断请求(INTST6)的时序。最后一个停止位一输出就产生该中断。

## 图 15-15 正常的发送完成中断请求时序

#### 1. 停止位宽度: 1



#### 2. 停止位宽度: 2



#### (d) 连续发送

当发送移位寄存器 6 (TXS6)一启动移位操作,就可以把下一个发送数据写入发送缓冲寄存器 6(TXB6)。因此,当发送完一帧数据后,即使在执行 INTST6 中断服务时也能够连续发送数据,从而实现高效率的通信速率。此外,当产生发送完成中断时通过读取 ASIF6 的第 0 位(TXSF6),可以对 TXB6 进行两次有效的写操作(2 个字节)而无须等待发送一帧数据的时间。

为了能够连续发送数据,必须根据 ASIF6 检查发送状态,判断是否可以对 TXB6 进行写操作,如果可以,则写入数据。

- 注意事项: 1. 在连续发送期间,ASIF6 寄存器的 TXBF6 和 TXSF6 标志从"10" 变成 "11", 再变成 "01"。因此检查状态时,不能通过比较 TXBF6 和 TXST6 来判断。在连续发送期间只读 TXBF6 标志。
  - 2. 在 LIN 模式下,不能使用连续发送功能。在将发送数据写入发送缓冲寄存器 6(TXB6)之前,异步串行接口发送状态寄存器 6(ASIF6)的值必须为 00H。

| TXBF6 | 对 TXB6 的写操作 |
|-------|-------------|
| 0     | 允许写操作       |
| 1     | 禁止写操作       |

注意事项: 为了能够连续发送数据,应将第一个发送的数据(第一个字节)写入 TXB6 中。之后,检查 TXBF6 标志位,必须为 "0"。如果正确,将下一个发送数据(第二个字节)写入 TXB6 中。如果 TXBF6 标志为 "1"时将数据写入 TXB6,则无法保证发送数据的正确性。

可用 TXSF6 标志位检测通信状态。

| TXSF6 | 发送状态      |
|-------|-----------|
| 0     | 发送操作结束    |
| 1     | 发送操作正在进行中 |

- 注意事项: 1. 如果要在连续发送结束时初始化发送单元,则在产生发送完成中断后必须检查 TXSF6 标志位, 应为 "0"。然后执行初始化操作。如果 TXSF6 标志为 "1"时执行初始化操作,则无法保证发 送数据的正确性。
  - 2. 在连续发送期间,当发送完一帧数据后执行 INTST6 中断服务之前下一个发送操作可能已经完成。计数测量时,可通过开发一个可以算发送数据的个数的程序或者通过参考 TXSF6 标志来实现检测。

图 15-16 为连续发送操作流程示例。

设置寄存器 写 TXB6 已执行了必须的 发送次数? 否 否 读 ASIF6 TXBF6=0? 是 写 TXB6 产生发送完成中 否 是 是 已执行了必须的 发送次数? 否 读 ASIF6 否 TXBF6=0? 是 发送过程完成

图 15-16 连续发送操作流程示例

备注: TXB6: 发送缓冲寄存器 6

ASIF6: 异步串行接口发送状态寄存器 6

TXBF6: ASIF6 的第 1 位(发送缓冲器数据标志位) TXSF6: ASIF6 的第 0 位(发送移位寄存器数据标志位) 图 15-17 显示了启动连续发送操作的时序,而图 15-18 显示了结束连续发送操作的时序。

图 15-17 启动连续发送操作的时序



**注:** 在读取 ASIF6 时,存在 TXBF6 和 TXSF6 = 1, 1 的情况。因此,仅用 TXBF6 就可以判断是否能进行 写操作。

**备注:** TxD6: TxD6 引脚(输出)

INTST6: 中断请求信号

TXB6: 发送缓冲寄存器 6 TXS6: 发送移位寄存器 6

ASIF6: 异步串行接口发送状态寄存器 6

TXBF6: ASIF6 的第 1 位 TXSF6: ASIF6 的第 0 位

## 图 15-18 结束连续发送操作的时序



**备注:** TxD6: TxD6 引脚(输出)

 INTST6:
 中断请求信号

 TXB6:
 发送缓冲寄存器 6

 TXS6:
 发送移位寄存器 6

ASIF6: 异步串行接口发送状态寄存器 6

TXBF6: ASIF6 的第 1 位 TXSF6: ASIF6 第 0 位

POWER6: 异步串行接口操作模式寄存器(ASIM6)的第7位 TXE6: 异步串行接口操作模式寄存器(ASIM6)的第6位

#### (e) 正常接收

当设置异步串行接口操作模式寄存器 6(ASIM6)的第7位(POWER6)=1, 然后将 ASIM0的第5位(RXE0)置1时, 允许接收并对 RxD6 引脚的输入进行采样。

当检测到 RxD6 引脚输入的下降沿时,波特率发生器的 8 位计数器开始计数。当计数值达到波特率发生器控制 寄存器 6(BRGC6)的设置值时,再次采样 RxD6 的输入信号(如图 15-19 中的 ▽)。如果此时 RxD6 为低电平,则认为输入信号为起始位。

当检测到起始位时,开始接收,以设置的波特率将串行数据依次存入接收移位寄存器 6(RXS6)中。当接收到停止位时,会产生接收完成中断信号(INTSR6),并且 RXS6 的数据被写入接收缓冲寄存器 6(RXB6)中。但如果出现溢出错误(OVE6),则接收到的数据不写入 RXB6。

即使在接收过程中出现校验错(PE6),接收仍然继续,直至接收到停止位,而在接收完成后会产生一个接收错误中断(INTSR6/INTSRE6)。

图 15-19 接收完成中断请求时序

- 注意事项: 1. 如果出现接收错误,则先后读取 ASIS6 和 RXB6,可将出错标志清零。否则,当接收到下一个数据时会产生溢出错误,而且接收错误状态保持不变。
  - 2. 接收始终按"停止位的个数 = 1"的情况执行,第2个停止位被忽略。
  - 3. 在读取 RXB6 之前,必须先读取异步串行接口接收错误状态寄存器 6(ASIS6)。

## (f) 接收错误

在接收期间有三种出错情况:校验错误、帧错误或溢出错误。作为数据接收的结果,作为数据接收的结果,如果异步串行接口接收错误状态寄存器 6(ASIS6)的出错标志位被置位,则将会产生一个接收错误中断请求信号(INTSR6/INTSRE6)。

在执行接收错误中断服务(INTSR6/INTSRE6)时读取 ASIS6 的内容,可确定接收期间出现的是何种错误(参见 图 15-6)。

读取 ASIS6 后,对其清零(0)。

表 15-3 产生接收错误的原因

| TO THE TAX PORT OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERTY OF THE PROPERT |                                     |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--|--|--|
| 接收错误                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 产生原因                                |  |  |  |
| 校验错误                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 发送数据的校验位与接收到的数据校验位不相等               |  |  |  |
| 帧错误                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 未检测到停止位                             |  |  |  |
| 溢出错误                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 在读取接收缓冲寄存器 6(RXB6)的数据前已完成下一个数据的接收操作 |  |  |  |

通过将异步串行接口操作模式寄存器 6(ASIM6)的第 0 位(ISRM6)清零,可以把接收错误中断划分为接收完成中断(INTSR6)和错误中断(INTSRE6)两部分。

#### 图 15-20 接收错误中断

1. 如果 ISRM6 被清零(接收完成中断 (INTSR6) 和接收错误中断 (INTSRE6)是分开的)
(a) 接收期间无错误 (b) 接收期间产生错误

| (d) 13.10.7911-17-11-16            | (6) 13 (8) 11-17 - 11-18 |              |  |  |  |  |
|------------------------------------|--------------------------|--------------|--|--|--|--|
| INTSR6                             |                          | INTSR6       |  |  |  |  |
| INTSRE6                            |                          | INTSRE6      |  |  |  |  |
| 2. 如果 ISRM6=1 (接收错误中断包含在 INTSR6 中) |                          |              |  |  |  |  |
| (a) 接收期间                           | 可无错误                     | (b) 接收期间产生错误 |  |  |  |  |

INTSR6 INTSR6 INTSRE6

#### (g) 接收数据的噪声过滤器

使用由预分频模块输出的基准时钟采样 RXD6 信号。

如果两次采样值相同,则匹配检测器的输出会发生变化,并把采样的数据作为输入数据。

噪声过滤器的电路结构如图 15-21 所示,接收操作的内部过程从外部信号状态开始延迟两个时钟才执行。

#### 图 15-21 噪声过滤器电路



#### (h) SBF 发送

在 LIN 模式中,可使用 SBF (同步中断区)发送控制功能进行发送。LIN 的发送操作参见图 15-1 LIN 的发送操作。

当异步串行接口模式寄存器 6(ASIM6)的第 7 位(POWER6)被设置为 1 时,TxD6 引脚输出高电平。接下来 ASIM6 的第 6 位(TXE6)被设置为 1 时,进入允许发送状态。且通过设置异步串行接口控制寄存器 6(ASICL6)的第 5 位(SBTT6)为 1,可启动 SBF 发送操作。

开始发送后,第  $13\sim20$  位(由 ASICL6 的第  $4\sim2$  位(SBL62  $\sim$  SBL60)设置)输出低电平。SBF 发送完毕后,产生发送完成中断请求(INTST6),且 SBTT6 被自动清零。接着,恢复到正常发送模式。直到下一次数据被发送到缓冲寄存器 6(TXB6)或 SBTT6 被设置为 1 时,才停止 SBF 发送。

图 15-22. SBF 发送



**备注:** TxD6: TxD6 引脚 (输出) INTST6: 发送完成中断请求

SBTT6: 异步串行接口控制寄存器 6 (ASICL6) 的第5位

#### (i) SBF接收

在 LIN 模式下,SBF 接收控制功能用于接收操作。需要了解 LIN 的接收操作,可参见**图 15-2 LIN 接收操作**。将 ASIM6 的第 7 位(POWER6)被设置为 1,然后再将 ASIM6 的第 5 位(RXE6)设置为 1,允许接收。当异步串行接口控制寄存器 6(ASICL6)的第 6 位(SBRT6)被设置为 1 时,允许 SBF 接收。在 SBF 接收允许状态下,对 RxD6 引脚进行采样,并以与正常接收允许状态下同样的方式检测起始位。

当检测到起始位时,启动接收操作,按照设置的波特率将串行数据依次存入接收移位寄存器 6(RXS6)中。在接收到停止位且 SBF 的宽度大于或等于 11 位时,与正常接收操作相同,将产生接收完成中断请求(INTSR6)。此时 SBRF6 和 SBRT6 被自动清零,SBF 接收操作结束。禁止检测 OVE6、PE6 和 FE6(异步串行接口接收错误状态寄存器 6(ASIS6)的  $0 \sim 2$  位)错误,不进行 UART 通信的错误检测。此外不执行接收移位寄存器 6(RXS6)和接收缓冲寄存器 6(RXB6)之间的数据传送,并保存复位值 FFH。如果 SBF 的宽度小于或等于 10 位,则在接收到停止位后不会产生出错中断,并恢复 SBF 接收模式。此时不对 SBRF6 和 SBRT6 位清零。

#### 图 15-23 SBF 接收

#### 1. 正常 SBF 接收 (检测到停止位, 且 SBF 宽度大于 10.5 位)



#### 2. SBF 接收错误 (检测到停止位,且 SBF 宽度小于或等于 10.5 位)



**备注:** RxD6: RxD6 引脚 (输入)

SBRT6: 异步串行接口控制寄存器 6 (ASICL6) 的第 6 位

SBRF6: ASICL6 的第 7 位 INTSR6: 接收完成中断请求

#### 15.4.3 专用波特率发生器

专用波特率发生器由一个源时钟选择器和一个 8 位可编程计数器组成,用于产生 UART6 发送/接收的串行时钟。 分别使用不同的 8 位计数器用于发送和接收。

#### (1) 波特率发生器的配置

#### • 基本时钟

该时钟由时钟选择寄存器 6(CKSR6)的第  $3\sim0$  位(TPS63 $\sim$ TPS60)选择。当异步串行接口操作模式寄存器 6(ASIM6)的第 7 位(POWER6)=1 时,将该时钟提供给每个模块。该时钟称为基本时钟,它的频率用 fxclk6 表示。当 POWER6 = 0 时,基本时钟恒为低电平。

#### • 发送计数器

当异步串行接口操作模式寄存器 6(ASIM6)的第7位(POWER6)或第6位(TXE6)=0时,该计数器停止计数,并被清零。

当 POWER6 = 1 且 TXE6 = 1 时计数器开始计数。

当第1个发送数据写入发送缓冲寄存器6(TXB6)时,计数器被清零。

如果连续发送数据,则当发送完 1 帧数据时计数器再次被清零。如果后面没有数据要发送,则计数器不被清零,而是继续计数直至 POWER6 或 TXE6 = 0。

### • 接收计数器

当异步串行接口操作模式寄存器 6(ASIM6)的第7位(POWER6)或第5位(RXE6)=0时,该计数器停止计数,并被清零。

当检测到起始位时, 计数器开始计数。

在收到一帧数据后计数器停止计数,直到下一个起始位被检测到时再重新开始计数。

POWFR6 fpRS 波特率发生器 fprs/2  $f_{\text{PRS}}/2^2$ POWER6, TXE6(或 RXE6) fprs/23 fprs/24 fprs/2<sup>5</sup> 选择器 8位计数器  $f_{\text{PRS}}/2^6$ fxclk6 fprs/27 fprs/28 fprs/29 fprs/210 ▶ 波特率 匹配检测器 1/2 8位定时器/ 事件计数器 50 输出 BRGC6:MDL67~MDL60 CKSR6:TPS63~TPS60

图 15-24 波特率发生器的配置

备注: POWER6: 异步串行接口操作模式寄存器 6 (ASIM6)的第7位

> TXE6: ASIM6 的第 6 位 RXE6: ASIM6 的第 5 位 CKSR6: 时钟选择寄存器6

BRGC6: 波特率发生器控制寄存器 6

### (2) 串行时钟的产生

使用时钟选择寄存器 6(CKSR6)和波特率发生器控制寄存器 6 (BRGC6)可产生串行时钟。 使用 CKSR6 的第 3  $\sim$  0 位(TPS63  $\sim$  TPS60),可以设置输入到 8 位计数器的时钟。使用 BRGC6 的 7  $\sim$  0 位 (MDL67  $\sim$  MDL60)设置 8 位计数器的分频值(fxclk6/8  $\sim$  fxclk6/255)。

表 15-4 TPS63 ~ TPS60 的设置值 TPS63 TPS62 基本时钟(fxclk6)的选择 TPS61 TPS60 fprs = fprs = fprs = fprs = 2 MHz 5 MHz 10 MHz 20 MHz 0 0 0 0 **F**PRS 2 MHz 5 MHz 10 MHz 20 MHz 0 5 MHz 0 0 1 fprs/2 1 MHz 2.5 MHz 10 MHz 0 0 1 2.5 MHz 0 fprs/22 500 kHz 1.25 MHz 5 MHz 0 0 1 1 fprs/23 250 kHz 625 kHz 1.25 MHz 2.5 MHz 1.25 MHz 0 1 0 0 fprs/24 125 kHz 312.5 kHz 625 kHz fprs/25 312.5 kHz 0 0 62.5 kHz 156.25 kHz 625 kHz 0 1 1 0 fprs/26 31.25 kHz 78.13 kHz 156.25 kHz 312.5 kHz 0 15.625 kHz 39.06 kHz 78.13 kHz 156.25 kHz 1 1 fprs/27 1 1 0 0 0 fprs/28 7.813 kHz 19.53 kHz 39.06 kHz 78.13 kHz 1 0 0 1 fprs/29 3.906 kHz 9.77 kHz 19.53 kHz 39.06 kHz fprs/2<sup>10</sup> 1.953 kHz 4.88 kHz 9.77 kHz 19.53 kHz 1 0 1 0 TM50 输出 1 0 1 1 其它情况 禁止设置

#### (a) 波特率

通过下列公式计算波特率。

• 波特率= 
$$\frac{\text{fxclk6}}{2 \times \text{k}}$$
 [bps]

fxclкє: 根据 CKSR6 的 TPS63  $\sim$  TPS60 位选择的基本时钟的频率 k: 根据 BRGC6 的 MDL67  $\sim$  MDL60 位设置的值(k = 8, 9, 10, ..., 255)

#### (b) 波特率误差

通过下列公式计算波特率误差。

注意事项: 1. 发送期间必须保持波特率误差在接收端允许的误差范围内。

2. 接收期间,波特率误差必须满足"(4)接收期间允许的波特率范围"中所描述的范围。

**举例:** 基本时钟频率 = 10 MHz = 10,000,000 Hz BRGC6 的 MDL67 
$$\sim$$
 MDL60  $\dot{\Omega}$  = 00100001B (k = 33) 目标波特率 = 153600 bps

波特率 = 
$$10 \text{ M/}(2 \times 33)$$
  
=  $10000000/(2 \times 33) = 151,515 \text{ [bps]}$ 

### (3) 波特率设置举例

表 15-5 波特率发生器的数据设置

| 波特率    |        | fprs = | 2.0 MHz |       |        | fprs = | 5.0 MHz |       | 1      | fprs = | 10.0 MHz |       |        | fprs = | 20.0 MHz |       |
|--------|--------|--------|---------|-------|--------|--------|---------|-------|--------|--------|----------|-------|--------|--------|----------|-------|
| [bps]  | TPS63- | k      | 计算值     | ERR   | TPS63- | k      | 计算值     | ERR   | TPS63- | k      | 计算值      | ERR   | TPS63- | k      | 计算值      | ERR   |
|        | TPS60  |        |         | [%]   | TPS60  |        |         | [%]   | TPS60  |        |          | [%]   | TPS60  |        |          | [%]   |
| 300    | 8H     | 13     | 301     | 0.16  | 7H     | 65     | 301     | 0.16  | 8H     | 65     | 301      | 0.16  | 9H     | 65     | 301      | 0.16  |
| 600    | 7H     | 13     | 601     | 0.16  | 6H     | 65     | 601     | 0.16  | 7H     | 65     | 601      | 0.16  | 8H     | 65     | 601      | 0.16  |
| 1200   | 6H     | 13     | 1202    | 0.16  | 5H     | 65     | 1202    | 0.16  | 6H     | 65     | 1202     | 0.16  | 7H     | 65     | 1202     | 0.16  |
| 2400   | 5H     | 13     | 2404    | 0.16  | 4H     | 65     | 2404    | 0.16  | 5H     | 65     | 2404     | 0.16  | 6H     | 65     | 2404     | 0.16  |
| 4800   | 4H     | 13     | 4808    | 0.16  | 3Н     | 65     | 4808    | 0.16  | 4H     | 65     | 4808     | 0.16  | 5H     | 65     | 4808     | 0.16  |
| 9600   | 3Н     | 13     | 9615    | 0.16  | 2H     | 65     | 9615    | 0.16  | 3Н     | 65     | 9615     | 0.16  | 4H     | 65     | 9615     | 0.16  |
| 19200  | 2H     | 13     | 19231   | 0.16  | 1H     | 65     | 19231   | 0.16  | 2H     | 65     | 19231    | 0.16  | 3H     | 65     | 19231    | 0.16  |
| 24000  | 1H     | 21     | 23810   | -0.79 | 3Н     | 13     | 24038   | 0.16  | 4H     | 13     | 24038    | 0.16  | 5H     | 13     | 24038    | 0.16  |
| 31250  | 1H     | 4      | 31250   | 0     | 4H     | 5      | 31250   | 0     | 5H     | 5      | 31250    | 0     | 6H     | 5      | 31250    | 0     |
| 38400  | 1H     | 13     | 38462   | 0.16  | 0H     | 65     | 38462   | 0.16  | 1H     | 65     | 38462    | 0.16  | 2H     | 65     | 38462    | 0.16  |
| 48000  | 0H     | 21     | 47619   | -0.79 | 2H     | 13     | 48077   | 0.16  | 3Н     | 13     | 48077    | 0.16  | 4H     | 13     | 48077    | 0.16  |
| 76800  | 0H     | 13     | 76923   | 0.16  | 0H     | 33     | 75758   | -1.36 | 0H     | 65     | 76923    | 0.16  | 1H     | 65     | 76923    | 0.16  |
| 115200 | 0H     | 9      | 111111  | -3.55 | 1H     | 11     | 113636  | -1.36 | ОΗ     | 43     | 116279   | 0.94  | 0H     | 87     | 114943   | -0.22 |
| 153600 | -      | -      | I       | -     | 1H     | 8      | 156250  | 1.73  | ОН     | 33     | 151515   | -1.36 | 1H     | 33     | 151515   | -1.36 |
| 312500 | _      | -      | -       | =     | 0H     | 8      | 312500  | 0     | 1H     | 8      | 312500   | 0     | 2H     | 8      | 312500   | 0     |

**备注:** TPS63 ~ TPS60: 时钟选择寄存器 6 (CKSR6)的 3  $\sim$  0 位 (用于设置基本时钟(fxclk6))

k: 使用波特率发生器控制寄存器 6 (BRGC6)的 MDL67  $\sim$  MDL60 位设置的值(k = 8, 9,

10, ..., 255)

fprs: 外部硬件时钟频率

ERR: 波特率误差

#### (4) 接收期间允许的波特率范围

接收期间来自发送端的波特率可允许的误差如下所示。

注意事项: 必须确保接收期间波特率误差在允许的误差范围内,可用以下公式计算。



图 15-25 接收期间允许的波特率范围

如图 15-25 所示,当检测到起始位后,接收数据的锁存时序由波特率发生器控制寄存器 6(BRGC6)设置的计数器确定。如果数据的最后一位(停止位)满足该锁存时序,则数据可被正确接收。假定接收数据为 11 位,各项理论值计算如下。

 $FL = (Brate)^{-1}$ 

 Brate:
 UART6 的波特率

 k:
 BRGC6 的设置值

 FL:
 1 位数据宽度

 锁存时序的极限: 2 个时钟

可允许的最小数据帧宽度: FLmin = 
$$11 \times FL - \frac{k-2}{2k} \times FL = \frac{21k+2}{2k}FL$$

因此在发送端设定的可接收的最大波特率如下所示。

BRmax = 
$$(FLmin/11)^{-1} = \frac{22k}{21k + 2}$$
 Brate

同样,可计算允许的最大数据帧宽度。

$$\frac{10}{11} \times FLmax = 11 \times FL - \frac{k+2}{2 \times k} \times FL = \frac{21k-2}{2 \times k} FL$$

$$FLmax = \frac{21k - 2}{20k} FL \times 11$$

因此在发送端设定的可接收的最小波特率如下所示。

BRmin = 
$$(FLmax/11)^{-1} = \frac{20k}{21k - 2}$$
 Brate

可通过上述最小和最大波特率公式计算在 UART6 与发送端之间允许的波特率误差,如下所示。

分频比(k) 允许的最大波特率误差 允许的最小波特率误差 8 +3.53% -3.61% 20 +4.26% -4.31% 50 +4.56% -4.58% 100 +4.66% -4.67% 255 +4.72% -4.73%

表 15-6 允许的最大/最小波特率误差

**备注: 1.** 接收时允许的误差与每帧的位数、输入时钟频率和分频比(k)有关。输入时钟频率和分频比(k)越高,允许的误差就越大。

2. k: BRGC6 设置的值

#### (5) 连续发送期间数据帧的宽度

当连续发送数据时,从停止位到下一个起始位的数据帧宽度比正常值延长了两个基本时钟。不过,由于在检测到起始位时接收端的时序被初始化,因此通信结果不会受到影响。

#### 图 15-26 连续发送期间数据帧的宽度



当 1 位数据宽度为 FL、停止位宽度为 FLstp,基本时钟频率为 fxclk6 时,有以下公式成立。

FLstp = FL + 2/fxclk6

因此,连续发送期间的数据帧宽度为:

数据帧宽度= 11 × FL + 2/fxclk6

### 第十六章 串行接口 CSI10 和 CSI11

### 16.1 串行接口 CSI10 和 CSI11 的功能

串行接口 CSI10 和 CSI11 有以下两种模式。

- 操作停止模式
- 3线串行 I/O 模式

#### (1) 操作停止模式

在不进行串行通信时可采用此模式,以降低功率消耗。 需要了解详细信息,可参见 **16.4.1 操作停止模式。** 

### (2) 3线串行 I/O 模式 (可选择 MSB-first / LSB-first)

该模式采用三条线(一条串行时钟线(SCKIn)和两条串行数据线(SIIn和 SOIn))传输 8 位数据。在 3 线串行 I/O 模式中数据通信时间可以缩短,因为发送和接收操作可以同步进行。 此外,可以指定采用 MSB-first 还是 LSB-first 传送 8 位数据,因此该接口可以连接任何设备。 3 线串行 I/O 模式用来连接采用时钟串行接口的外部 IC 和显示控制器。。 需要了解详细信息,可参见 **16.4.2 3 线串行 I/O 模式**。

### 16.2 串行接口 CSI10 和 CSI11 的配置

串行接口 CSI10 和 CSI11 包括以下硬件。

表 16-1 串行接口 CSI10 和 CSI11 的配置

| 项目    | 配置                                                                                                               |
|-------|------------------------------------------------------------------------------------------------------------------|
| 控制器   | 发送控制器<br>时钟启动/停止控制器 & 时钟相位控制器                                                                                    |
| 寄存器   | 发送缓冲寄存器 ln (SOTB ln)<br>串行 I/O 移位寄存器 ln (SIO1n)                                                                  |
| 控制寄存器 | 串行操作模式寄存器 ln (CSIMln)<br>串行时钟选择寄存器 ln (CSICln)<br>端口模式寄存器 0 (PM0) 或端口模式寄存器 1 (PM1)<br>端口寄存器 0 (P0) 或端口寄存器 1 (P1) |

**备注:** n = 0, 1

图 16-1 串行接口 CSI10 的框图



**备注:** (a): SO10 输出

图 16-2 串行接口 CSI11 的框图



**备注:** (a): SO11 输出

#### (1) 发送缓冲寄存器 1n (SOTB1n)

该寄存器用于设置发送数据。

当串行操作模式寄存器 1n(CSIM1n)的第7位(CSIE1n)和第6位(TRMD1n)均为1时,通过将数据写入SOTB1n来启动发送/接收操作。

使用串行 I/O 移位寄存器 ln 将写入 SOTBln 的并行数据转换成串行数据,并把数据输出到串行输出引脚 (SOln)。

可由8位存储器操作指令对SOTB1n进行读写。

复位信号的产生将该寄存器清零(00H)。

#### 注意事项: 1. 当 CSOT1n = 1 (在串行通信期间) 时不要访问 SOTB1n。

2. 在从设备模式中,在低电平被输入到 SSI11 引脚时把数据写入 SOTB11,将启动发送/接收操作。需要了解发送/接收操作的详细信息,可参见 16.4.2 (2) 通信操作。

#### (2) 串行 I/O 移位寄存器 1n (SIO1n)

该8位寄存器可将并行数据转换成串行数据,反之亦然。

可由8位存储器操作指令对寄存器进行读操作。

如果串行操作模式寄存器 ln (CSIM1n) 的第 6 位 (TRMD1n) = 0,则从 SIO1n 读取数据可启动接收操作。

接收期间,将数据从串行输入引脚(SIIn)读到SIOIn中。

复位信号的产生将该寄存器清零(00H)。

#### 注意事项: 1. 当 CSOT1n = 1 (在串行通信期间) 时不要访问 SIO1n。

2. 在从设备模式中,在低电平输入到 SSI11 引脚时从 SIO11 读取数据,将启动接收操作。需要了解接收操作的详细信息,可参见 16.4.2 (2) 通信操作。

### 16.3 控制串行接口 CSI10 和 CSI11 的寄存器

串行接口 CSI10 和 CSI11 由以下四个寄存器控制。

- 串行操作模式寄存器 ln (CSIM1n)
- 串行时钟选择寄存器 ln (CSIC1n)
- 端口模式寄存器 0 (PM0) 或端口模式寄存器 1 (PM1)
- 端口寄存器 0 (P0) 或端口寄存器 1 (P1)

### (1) 串行操作模式寄存器 1n (CSIM1n)

CSIM1n用于选择操作模式、允许或禁止操作。 可由 1 位或 8 位存储器操作指令设置 CSIM1n。 复位信号的产生将该寄存器清零(00H)。

备注: n = 0, 1

#### 图 16-3 串行操作模式寄存器 10 (CSIM10) 的格式

地址: FF80H 复位后: 00H R/W \*\*1

| 符号     | <7>    | 6      | 5 | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|---|-------|---|---|---|--------|
| CSIM10 | CSIE10 | TRMD10 | 0 | DIR10 | 0 | 0 | 0 | CSOT10 |

| CSIE10 | 3线串行 I/O 模式中的操作控制                          |
|--------|--------------------------------------------|
| 0      | 禁止操作 <sup>推2</sup> 且异步复位内部电路 <sup>推3</sup> |
| 1      | 允许操作                                       |

| TRMD10 <sup>推4</sup> | 发送/接收模式控制   |
|----------------------|-------------|
| O <sup>推5</sup>      | 接收模式 (禁止发送) |
| 1                    | 发送/接收模式     |

| DIR10 <sup>26</sup> | 规定起始位 |
|---------------------|-------|
| 0                   | MSB   |
| 1                   | LSB   |

| С | SOT10 | 通信状态标志  |
|---|-------|---------|
|   | 0     | 通信停止    |
|   | 1     | 通信正在进行中 |

#### 注: 1. 第0位只读。

- 2. 若将 P10/SCK10/TxD0 和 P12/SO10 用作通用端口,设置 CSIC10 为默认状态(00H)。
- 3. 对 CSIM10 的第 0 位 (CSOT10) 和串行 I/O 移位寄存器 10 (SIO10) 进行复位。
- **4.** 当 CSOT10 = 1 (在串行通信期间) 时不要重写 TRMD10。
- **5.** 当 TRMD10 = 0 时, SO10 输出(参见**图 16-1(a)**)恒为低电平。当从 SIO10 读取数据时,启动接收操作。 **6.** 当 CSOT10 = 1(在串行通信期间)时不要重写 DIR10。

注意事项: 第5位必须清零。

373

#### 图 16-4 串行操作模式寄存器 11 (CSIM11) 的格式

地址: FF88H 复位后: 00H R/W \*\*1

| 符号     | <7>    | 6      | 5     | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|-------|-------|---|---|---|--------|
| CSIM11 | CSIE11 | TRMD11 | SSE11 | DIR11 | 0 | 0 | 0 | CSOT11 |

| CSIE11 | 3线串行 I/O 模式中的操作控制                          |
|--------|--------------------------------------------|
| 0      | 禁止操作 <sup>推2</sup> 并异步复位内部电路 <sup>推3</sup> |
| 1      | 允许操作                                       |

| TR | RMD11 <sup>推4</sup> | 发送/接收模式控制   |
|----|---------------------|-------------|
|    | 0                   | 接收模式 (禁止发送) |
|    | 1                   | 发送/接收模式     |

| SSE11 * 6,7 | SSI11 引脚使用选择 |
|-------------|--------------|
| 0           | 不使用 SSII1 引脚 |
| 1           | 使用 SSII1 引脚  |

| DIR11 <sup>±8</sup> | 规定起始位 |
|---------------------|-------|
| 0                   | MSB   |
| 1                   | LSB   |

| CSOT11 | 通信状态标志  |
|--------|---------|
| 0      | 通信停止    |
| 1      | 通信正在进行中 |

# **注:** 1. 第0位只读。

- 2. 若将 P02/SO11, P04/SCK11 和 P05/SSI11/TI001 用作通用端口,设置 CSIC11 为默认状态(00H)。
- 3. 对 CSIM11 的第 0 位 (CSOT11) 和串行 I/O 移位寄存器 11 (SIO11) 进行复位。
- **4.** 当 CSOT11 = 1 (在串行通信期间)时不要重写 TRMD11。
- 5. 当 TRMD11 = 0 时, SO11 输出(参见图 16-2(a))恒为低电平。当从 SIO11 读取数据时,启动接收操作。
- **6.** 当 CSOT11 = 1 (在串行通信期间)时不要重写 SSE11。
- 7. 在将该位设置为 1之前, $\overline{SSIII}$  引脚输入电平恒为 0 或 1。
- 8. 当 CSOT11 = 1 (在串行通信期间) 时不要重写 DIR11。

#### (2) 串行时钟选择寄存器 1n (CSIC1n)

该寄存器规定数据发送/接收的时序,并设置串行时钟。

可由1位或8位存储器操作指令设置CSIC1n。

复位信号的产生将寄存器清零(00H)。

备注: n = 0, 1

# 图 16-5 串行时钟选择寄存器 10 (CSIC10) 的格式

地址: FF81H 复位后: 00H R/W

| Symbol | 7 | 6 | 5 | 4     | 3     | 2      | 1      | 0      |
|--------|---|---|---|-------|-------|--------|--------|--------|
| CSIC10 | 0 | 0 | 0 | CKP10 | DAP10 | CKS102 | CKS101 | CKS100 |

| CKP10 | DAP10 | 规定数据发送/接收的时序 | 类型 |
|-------|-------|--------------|----|
| 0     | 0     | SCK10        | 1  |
| 0     | 1     | SCK10        | 2  |
| 1     | 0     | SCK10        | 3  |
| 1     | 1     | SCK10        | 4  |

| CKS102 | CKS101 | CKS100 | CKS100 CSI10 串行时钟的选择 |                          |                          |                           |                           |       |  |
|--------|--------|--------|----------------------|--------------------------|--------------------------|---------------------------|---------------------------|-------|--|
|        |        |        |                      | f <sub>PRS</sub> = 2 MHz | f <sub>PRS</sub> = 5 MHz | f <sub>PRS</sub> = 10 MHz | f <sub>PRS</sub> = 20 MHz |       |  |
| 0      | 0      | 0      | fprs/2               | 1 MHz                    | 2.5 MHz                  | 5 MHz                     | 10 MHz                    | 主设备模式 |  |
| 0      | 0      | 1      | fprs/2 <sup>2</sup>  | 500 kHz                  | 1.25 MHz                 | 2.5 MHz                   | 5 MHz                     |       |  |
| 0      | 1      | 0      | fprs/2 <sup>3</sup>  | 250 kHz                  | 625 kHz                  | 1.25 MHz                  | 2.5 MHz                   |       |  |
| 0      | 1      | 1      | fprs/24              | 125 kHz                  | 312.5 kHz                | 625 kHz                   | 1.25 MHz                  |       |  |
| 1      | 0      | 0      | fprs/2 <sup>5</sup>  | 62.5 kHz                 | 156.25 kHz               | 312.5 kHz                 | 625 kHz                   |       |  |
| 1      | 0      | 1      | fprs/2 <sup>6</sup>  | 31.25 kHz                | 78.13 kHz                | 156.25 kHz                | 312.5 kHz                 |       |  |
| 1      | 1      | 0      | fprs/2 <sup>7</sup>  | 15.63 kHz                | 39.06 kHz                | 78.13 kHz                 | 156.25 kHz                |       |  |
| 1      | 1      | 1      | 输入到                  | SCK10 的外语                | 部时钟                      |                           | •                         | 从设备模式 |  |

### 注意事项: 1. 当 CSIE10=1 时(允许操作),不要对 CSIC10 进行写操作。

- 2. 若将 P10/SCK10/TxD0 和 P12/SO10 用作通用端口,设置 CSIC10 为默认状态(00H)。
- 3. 复位后数据时钟的相位类型为类型 1。

备注: fprs: 外部硬件时钟频率

#### 图 16-6 串行时钟选择寄存器 11 (CSIC11) 的格式

地址: FF89H 复位后: 00H R/W

| 符号     | 7 | 6 | 5 | 4     | 3     | 2      | 1      | 0      |
|--------|---|---|---|-------|-------|--------|--------|--------|
| CSIC11 | 0 | 0 | 0 | CKP11 | DAP11 | CKS112 | CKS111 | CKS110 |

| CKP11 | DAP11 | 规定数据发送/接收时序 | 类型 |
|-------|-------|-------------|----|
| 0     | 0     | SCK11       | 1  |
| 0     | 1     | SCK11       | 2  |
| 1     | 0     | SCK11       | 3  |
| 1     | 1     | SCK11       | 4  |

| CKS112 | CKS111 | CKS110 |                     | CSI11 串行时钟选择             |                          |                           |                           |       |  |
|--------|--------|--------|---------------------|--------------------------|--------------------------|---------------------------|---------------------------|-------|--|
|        |        |        |                     | f <sub>PRS</sub> = 2 MHz | f <sub>PRS</sub> = 5 MHz | f <sub>PRS</sub> = 10 MHz | f <sub>PRS</sub> = 20 MHz |       |  |
| 0      | 0      | 0      | fprs/2              | 1 MHz                    | 2.5 MHz                  | 5 MHz                     | 10 MHz                    | 主设备模式 |  |
| 0      | 0      | 1      | fprs/2 <sup>2</sup> | 500 kHz                  | 1.25 MHz                 | 2.5 MHz                   | 5 MHz                     |       |  |
| 0      | 1      | 0      | fprs/2 <sup>3</sup> | 250 kHz                  | 625 kHz                  | 1.25 MHz                  | 2.5 MHz                   |       |  |
| 0      | 1      | 1      | fprs/24             | 125 kHz                  | 312.5 kHz                | 625 kHz                   | 1.25 MHz                  |       |  |
| 1      | 0      | 0      | fprs/2 <sup>5</sup> | 62.5 kHz                 | 156.25 kHz               | 312.5 kHz                 | 625 kHz                   |       |  |
| 1      | 0      | 1      | fprs/2 <sup>6</sup> | 31.25 kHz                | 78.13 kHz                | 156.25 kHz                | 312.5 kHz                 |       |  |
| 1      | 1      | 0      | fprs/27             | 15.63 kHz                | 39.06 kHz                | 78.13 kHz                 | 156.25 kHz                |       |  |
| 1      | 1      | 1      | 输入到                 | SCK11 的外i                | 部时钟                      |                           |                           | 从设备模式 |  |

注意事项: 1. 当 CSIE11=1 时(允许操作),不要对 CSIC11 进行写操作。

★ 2. 若将 P02/SO11 和 P04/SCK11 用作通用端口,设置 CSIC11 为默认状态(00H)。

3. 复位后数据时钟的相位类型为类型 1。

**备注:** fprs: 外部硬件时钟频率

#### (3) 端口模式寄存器 0 和 1 (PM0, PM1)

这两个寄存器用于按位设置端口0和1的输入/输出操作模式。

当 P10/SCK10 和 P04/SCK11 用作串行接口的时钟输出引脚时,对 PM10 和 PM04 清零,并将 P10、P04 的输出锁存器的值设置为 1。

当 P12/SO10 和 P02/SO11 用作串行接口的数据输出引脚时,则对 PM12 和 PM02 清零,并将 P12 和 P02 的输出锁存器的值设置为 0。

当 P10/SCK10 和 P04/SCK11 用作串行接口的时钟输入引脚、P11/SI10/RxD0 和 P03/SI11 用作数据输入引脚而 P05/SSI11/TI001 用作片选输入引脚时,将 PM10、PM04、PM11、PM03 和 PM05 设置为 1。此时,P10、P04、P11、P03 和 P05 的输出锁存值可以为 0 或 1。

可由1位或8位存储器操作指令设置PM0和PM1。

复位信号的产生将这两个寄存器的值设置为 FFH。

图 16-7 端口模式寄存器 0 (PM0)的格式

| 地址: F | FE20H | 复    | 夏位后: | FFH  | R/W  |      |      |      |
|-------|-------|------|------|------|------|------|------|------|
| 符号    | 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| PM0   | 1     | PM06 | PM05 | PM04 | PM03 | PM02 | PM01 | PM00 |

| PM0r | P0n 引脚 I/O 模式选择(n=0~6) |
|------|------------------------|
| 0    | 输出模式 (输出缓冲器打开)         |
| 1    | 输入模式(输出缓冲器关闭)          |

图 16-8 端口模式寄存器 1 (PM1) 的格式

| 地址: F | F21H | 复    | [位后: | FFH  | R/W  |      |      |      |
|-------|------|------|------|------|------|------|------|------|
| 符号    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| PM1   | PM17 | PM16 | PM15 | PM14 | PM13 | PM12 | PM11 | PM10 |

| PM1n | P1n 引脚 I/O 模式选择(n=0~7) |
|------|------------------------|
| 0    | 输出模式(输出缓冲器打开)          |
| 1    | 输入模式(输出缓冲器关闭)          |

### 16.4 串行接口 CSI10 和 CSI11 的操作

串行接口 CSI10 和 CSI11 可在以下两种模式中使用。

- 操作停止模式
- 3线串行 I/O 模式

#### 16.4.1 操作停止模式

在此模式下,不能进行串行通信,因此,可降低功率消耗。此外,P10/SCK10/TxD0,P11/SI10/RxD0,P12/SO10,P02/SO11,P03/SI11 和 P04/SCK11 在此模式下可作为通用 I/O 端口引脚使用。

### (1) 使用的寄存器

由串行操作模式寄存器 ln (CSIM1n) 设置操作停止模式。通过将 CSIM1n 的第 7 位 (CSIE1n) 清零,设置该模式。

#### (a) 串行操作模式寄存器 1n (CSIM1n)

可由 1 位或 8 位存储器操作指令设置 CSIM1n。 复位信号的产生将 CSIM1n 清零(00H)。

备注: n = 0, 1

• 串行操作模式寄存器 10 (CSIM10)

地址: FF80H 复位后: 00H R/W

| 符号     | <7>    | 6      | 5 | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|---|-------|---|---|---|--------|
| CSIM10 | CSIE10 | TRMD10 | 0 | DIR10 | 0 | 0 | 0 | CSOT10 |

| CSIE10 | 3 线串行 I/O 模式中的操作控制                          |
|--------|---------------------------------------------|
| 0      | 禁止操作 <sup>性1</sup> ,并异步复位内部电路 <sup>性2</sup> |

- ★ 注: 1. 若将 P10/SCK10/TxD0 和 P12/SO10 用作通用端口,设置 CSIC10 为默认状态(00H)。
  - 2. 对 CSIM10 的第 0 位 (CSOT10) 和串行 I/O 移位寄存器 10 (SIO10) 进行复位。
  - 串行操作模式寄存器 11 (CSIM11)

地址: FF88H 复位后: 00H R/W

| 符号     | <7>    | 6      | 5     | 4     | 3 | 2 | 1 | 0      |
|--------|--------|--------|-------|-------|---|---|---|--------|
| CSIM11 | CSIE11 | TRMD11 | SSE11 | DIR11 | 0 | 0 | 0 | CSOT11 |

| CSIE11 | 3线串行 I/O 模式中的操作控制                           |  |  |  |  |  |  |
|--------|---------------------------------------------|--|--|--|--|--|--|
| 0      | 禁止操作 <sup>推1</sup> ,并异步复位内部电路 <sup>推2</sup> |  |  |  |  |  |  |

- ★ 注: 1. 若将 P02/SO11, P04/SCK11 和 P05/SSI11/TI001 用作通用端口,设置 CSIC11 为默认状态 (00H)
  - 2. 对 CSIM11 的第 0 位 (CSOT11) 和串行 I/O 移位寄存器 11 (SIO11) 进行复位。

#### 16.4.2 3线串行 I/O 模式

3 线串行 I/O 模式用来连接采用时钟串行接口的外部 IC 和显示控制器。该模式中使用三条线进行通信: 串行时钟(SCKIn)、串行输出(SOIn)和串行输入(SIIn)线。

#### (1) 使用的寄存器

- 串行操作模式寄存器 1n (CSIM1n)
- 串行时钟选择寄存器 ln (CSIC1n)
- 端口模式寄存器 0 (PM0) 或端口模式寄存器 1 (PM1)
- 端口寄存器 0 (P0) 或端口寄存器 1 (P1)

3线串行 I/O 模式设置操作的基本步骤如下。

- <1> 设置 CSIC1n 寄存器 (参见 图 16-5 和 16-6)
- <2> 设置 CSIM1n 寄存器的第 0 位和第 4 ~ 6 位 (CSOT1n、DIR1n、SSE11 (仅见于串行接口 CSI11) 和 TRMD1n) (参见 图 16-3 和 16-4)。
- <3> CSIM1n 的第 7 位 (CSIE1n) 置 1。 → 允许发送/接收。
- <4> 将数据写入发送缓冲寄存器  $\ln$  (SOTB $\ln$ )。  $\rightarrow$  启动发送/接收操作。 从串行 I/O 移位寄存器  $\ln$  (SIO $\ln$ ) 中读取数据。  $\rightarrow$  启动数据接收操作。

注意事项: 在设置端口模式寄存器和端口寄存器时,要考虑与通信另一方的关系。

寄存器设置与引脚之间的关系如下所示。

### 表 16-2 寄存器设置与引脚之间的关系 (1/2)

### (a) 串行接口 CSI10

| CSIE10 | TRMD10 | PM11             | P11              | PM12             | P12              | PM10             | P10              | CSI10                      |                   | 引脚功能     |                             |
|--------|--------|------------------|------------------|------------------|------------------|------------------|------------------|----------------------------|-------------------|----------|-----------------------------|
|        |        |                  |                  |                  |                  |                  |                  | 操作                         | SI10/RxD0/<br>P11 | SO10/P12 | SCK10/<br>TxD0/P10          |
| 0      | ×      | × <sup>注 1</sup> | × <sup>注 1</sup> | × <sup>注 1</sup> | × <sup>注 1</sup> | × <sup>注 1</sup> | × <sup>注 1</sup> | 停止                         | RxD0/P11          | P12      | TxD0/<br>P10 <sup>注 2</sup> |
| 1      | 0      | 1                | ×                | × <b>注</b> 1     | × <sup>注 1</sup> | 1                | ×                | 从设备接收 <sup>准3</sup>        | SI10              | P12      | SCK10<br>(输入) <sup>注3</sup> |
| 1      | 1      | × <sup>注 1</sup> | × <sup>注 1</sup> | 0                | 0                | 1                | ×                | 从设备发送 <sup>產3</sup>        | RxD0/P11          | SO10     | SCK10<br>(输入) <sup>注3</sup> |
| 1      | 1      | 1                | ×                | 0                | 0                | 1                | ×                | 从设备发送/<br>接收 <sup>胜3</sup> | SI10              | SO10     | SCK10<br>(输入) <sup>胜3</sup> |
| 1      | 0      | 1                | ×                | × <b>注</b> 1     | × <sup>注 1</sup> | 0                | 1                | 主设备接收                      | SI10              | P12      | SCK10<br>(输出)               |
| 1      | 1      | × <sup>注 1</sup> | × <sup>注 1</sup> | 0                | 0                | 0                | 1                | 主设备发送                      | RxD0/P11          | SO10     | SCK10<br>(输出)               |
| 1      | 1      | 1                | ×                | 0                | 0                | 0                | 1                | 主设备发送/<br>接收               | SI10              | SO10     | SCK10<br>(输出)               |

注: 1. 可用作端口引脚。

**2.** 如果 P10/SCK10/TxD0 用作端口引脚,则将 CKP10 清零。

3. 如果使用从设备模式,则须将 CKS102、CKS101 和 CKS100 设置为 1、1 和 1。

**备注:** ×: 不必考虑

CSIE10: 串行操作模式寄存器 10 (CSIM10) 的第 7 位

TRMD10: CSIM10 的第 6 位

CKP10: 串行时钟选择寄存器 10 (CSIC10) 的第 4 位

CKS102, CKS101, CKS100: CSIC10 的第 0 ~ 2 位

 PM1×:
 端口模式寄存器

 P1×:
 端口输出锁存器

#### 表 16-2 寄存器设置与引脚之间的关系 (2/2)

### (b) 串行接口 CSI11

| CSIE11 | TRMD11 | SSE11 | PM03             | P03              | PM02             | P02              | PM04            | P04              | PM05             | P05              | CSI11                      |              | 引用           | 却功能               |                     |
|--------|--------|-------|------------------|------------------|------------------|------------------|-----------------|------------------|------------------|------------------|----------------------------|--------------|--------------|-------------------|---------------------|
|        |        |       |                  |                  |                  |                  |                 |                  |                  |                  | 操作                         | SI11/<br>P03 | SO11/<br>P02 | SCK11/<br>P04     | SSI11/<br>TI001/P05 |
| 0      | ×      | ×     | × <sup>注1</sup>  | × <sup>注1</sup>  | × <sup>注1</sup>  | × <sup>注 1</sup> | × <sup>注1</sup> | × <sup>注 1</sup> | × <sup>注1</sup>  | × <sup>注1</sup>  | 停止                         | P03          | P02          | P04 <sup>注2</sup> | TI001/<br>P05       |
| 1      | 0      | 0     | 1                | ×                | × <sup>注 1</sup> | × <sup>注 1</sup> | 1               | ×                | × <sup>注 1</sup> | × <sup>注 1</sup> | 从设备接收 <sup>在3</sup>        | SI11         | P02          | SCK11<br>(输入)     | TI001/<br>P05       |
|        |        | 1     |                  |                  |                  |                  |                 |                  | 1                | ×                |                            |              |              | 注3                | SSI11               |
| 1      | 1      | 0     | × <sup>注 1</sup> | × <sup>注 1</sup> | 0                | 0                | 1               | ×                | × <sup>注1</sup>  | × <sup>注 1</sup> | 从设备发送 <sup>产3</sup>        | P03          | SO11         | SCK11<br>(输入)     | TI001/<br>P05       |
|        |        | 1     |                  |                  |                  |                  |                 |                  | 1                | ×                |                            |              |              | 注3                | SSI11               |
| 1      | 1      | 0     | 1                | ×                | 0                | 0                | 1               | ×                | × <sup>注1</sup>  | × <sup>注1</sup>  | 从设备发送/<br>接收 <sup>建3</sup> | SI11         | SO11         | SCK11<br>(输入)     | TI001/<br>P05       |
|        |        | 1     |                  |                  |                  |                  |                 |                  | 1                | ×                | 13.13                      |              |              | 注 3               | SSI11               |
| 1      | 0      | 0     | 1                | ×                | × <sup>注1</sup>  | × <sup>注 1</sup> | 0               | 1                | × <sup>注1</sup>  | × <sup>注1</sup>  | 主设备接收                      | SI11         | P02          | SCK11<br>(输出)     | TI001/<br>P05       |
| 1      | 1      | 0     | × <sup>注 1</sup> | × <sup>注 1</sup> | 0                | 0                | 0               | 1                | × <sup>注 1</sup> | × <sup>注 1</sup> | 主设备发送                      | P03          | SO11         | SCK11<br>(输出)     | TI001/<br>P05       |
| 1      | 1      | 0     | 1                | ×                | 0                | 0                | 0               | 1                | × <sup>注1</sup>  | × <sup>注 1</sup> | 主设备发送/<br>接收               | SI11         | SO11         | SCK11<br>(输出)     | TI001/<br>P05       |

注: 1. 可用作端口引脚。

2. 如果 P04/SCK11 用作端口引脚,则将 CKP11 清零。

3. 如果使用从设备模式,则须将 CKS112、CKS111 和 CKS110 设置为 1、1 和 1。

**备注:** ×: 不必考虑

**CSIE11**: 串行操作模式寄存器 11 (**CSIM**11) 的第 7 位

TRMD11: CSIM11 的第 6 位

**CKP11**: 串行时钟选择寄存器 11 (CSIC11) 的第 4 位

#### (2) 通信操作

在3线串行I/O模式中,是以8位为单元发送或接收数据。每位数据与串行时钟同步地发送或接收。

当串行操作模式寄存器  $\ln (CSIM1n)$  的第 6 位 (TRMD1n) =1 时,允许发送或接收数据。当数据被写入到发送缓冲寄存器  $\ln (SOTB1n)$  时,开始进行发送/接收。此外,串行操作模式寄存器  $\ln (CSIM1n)$ 的第 6 位 (TRMD1n) = 0 时,允许接收数据。

当数据从串行 I/O 移位寄存器 In (SIO1n) 被读出时, 启动接收操作。

然而当串行接口 CSI11 是在从设备模式下工作,且 CSIM11 的第 5 位 (SSE11) =1 时,通信操作如下。

- <1> SSI11 引脚输入为低电平
  - → 在对 SOTB11 进行写操作时开始进行发送/接收,或者在读取 SIO11 时启动接收操作。
- <2> SSI11 引脚输入为高电平
  - → 保持发送/接收或接收状态,即使对 SOTB11 进行写操作或读取 SIO11,也不能启动发送/接收或接收操作。
- <3> 当 SSIII 引脚为高电平输入时将数据写入 SOTB11 或从 SIO11 读取数据,然后 SSIII 引脚输入变为低电平。
  - → 启动发送/接收或接收操作。
- <4> 在发送/接收或接收期间 SSI11 引脚输入为高电平。
  - → 暂停执行发送/接收或接收操作。

通信开始后,CSIM1n 的第 0 位(CSOT1n)=1。当 8 位数据通信结束时,设置通信完成中断请求标志(CSIIF1n),且对 CSOT1n清零。这样允许进行下一个通信。

注意事项: 1. 当 CSOT1n = 1 时(串行通信期间),不要访问控制寄存器和数据寄存器。

2. 当使用串行接口 CSI11 时,在从设备模式下,启动时钟操作改变 SSI11 引脚的电平之前至少要等待 一个时钟,否则可能发生错误。

#### 图 16-9 3 线串行 I/O 模式中的时序 (1/2)

# (a) 发送/接收时序 (类型 1: TRMD1n = 1, DIR1n = 0, CKP1n = 0, DAP1n = 0, SSE11 = 1 <sup>±</sup>)



注: SSE11 标志和 SSI11 引脚仅见于串行接口 CSI11,并且在从设备模式中使用。

#### 图 16-9 3线串行 I/O 模式中的时序 (2/2)

# (b) 发送/接收时序 (类型 2: TRMD1n = 1, DIR1n = 0, CKP1n = 0, DAP1n = 1, SSE11 = 1 <sup>t</sup>)



注: SSE11 标志和 SSI11 引脚仅见于串行接口 CSI11,并且在从设备模式中使用。

#### 图 16-10 时钟/数据相位的时序

### (a) 类型 1: CKP1n = 0, DAP1n = 0, DIR1n = 0



### (b) 类型 2: CKP1n = 0, DAP1n = 1, DIR1n = 0



### (c) 类型 3: CKP1n = 1, DAP1n = 0, DIR1n = 0



### (d) 类型 4: CKP1n = 1, DAP1n = 1, DIR1n = 0



#### 备注: 1. n = 0, 1

2. 上图显示了一个通信操作过程,即采用 MSB first 发送数据。

#### (3) 输出到 SO1n 引脚的时序 (起始位)

通信开始后,将发送缓冲寄存器 ln (SOTBln) 的值从 SOln 引脚输出。此时起始位的输出操作如下所示。

#### 图 16-11 起始位的输出操作 (1/2)

(a) 类型 1: CKP1n = 0, DAP1n = 0



(b) 类型 3: CKP1n = 1, DAP1n = 0



在 SCKIn 的下降沿(或上升沿),起始位数据通过 SOTBIn 寄存器被直接锁存到输出锁存器,并通过输出选择器从 SOIn 引脚输出。然后在 SCKIn 下一个上升沿(或下降沿)将 SOTBIn 寄存器的内容传送到 SIOIn 中,并移出 1 位。同时,通过 SIIn 引脚将接收数据的起始位存储到 SIOIn 寄存器中。

在下一个 SCKIn 的下降沿(或上升沿),通过 SIO1n 寄存器将第 2 位以及随后各位锁存到输出锁存器,然后从 SO1n 引脚输出数据。

图 16-11 起始位的输出操作(2/2)

(c) 类型 2: CKP1n = 0, DAP1n = 1



(d) 类型 4: CKP1n = 1, DAP1n = 1



在 SOTB1n 的写信号或 SIO1n 的读信号的下降沿,起始位数据通过 SOTB1n 寄存器被直接锁存,并通过输出选择器 从 SO1n 引脚输出。然后在 SCK1n 下一个下降沿(或上升沿)将 SOTB1n 寄存器的内容传送到 SIO1n 中,并移出 1 位。同时,将接收数据的起始位通过 SI1n 引脚存储到 SIO1n 寄存器。

在下一个  $\overline{SCK1n}$  的上升沿(或下降沿),通过 SIO1n 寄存器将第 2 位以及随后各位锁存到输出锁存器,然后从 SO1n 引脚输出数据。

#### (4) SO1n 引脚的输出值 (终止位)

在通信完成后, SO1n 引脚保存终止位的输出值。

图 16-12 SO1n 引脚的输出值 (终止位) (1/2)

(a) 类型 1: CKP1n = 0, DAP1n = 0



(b) 类型 3: CKP1n = 1, DAP1n = 0



### 图 16-12 SO1n 引脚的输出值 (终止位) (2/2)

# (c) 类型 2: CKP1n = 0, DAP1n = 1



### (d) 类型 4: CKP1n = 1, DAP1n = 1



#### (5) SO1n 输出 (参见图 16-1 和 16-2 (a))

如果串行操作模式寄存器 ln (CSIM1n) 的第7位(CSIE1n) 被清零,则 SO1n 输出状态如下。

表 16-3 SO1n 输出状态

| TRMD1n                     | DAP1n     | DIR1n     | SO1n 输出 <sup>±1</sup> |  |
|----------------------------|-----------|-----------|-----------------------|--|
| TRMD1n = 0 <sup>1± 2</sup> | -         | -         | 输出低电平 <sup>推 2</sup>  |  |
| TRMD1n = 1                 | DAP1n = 0 | _         | SOIn 锁存值<br>(低电平输出)   |  |
|                            | DAP1n = 1 | DIR1n = 0 | SOTB1n 第7位的值          |  |
|                            |           | DIR1n = 1 | SOTB1n 第 0 位的值        |  |

- **注:** 1. 根据 PM12 与 P12、或 PM02 与 P02,以及 SO1n 的输出,决定 SO10/P12 或者 SO11/P02 引脚的实际输出
  - 2. 复位后的状态

注意事项: 如果对 TRMD1n、DAP1n 和 DIR1n 进行写操作,则 SO1n 的输出值将发生改变。

### 第十七章 串行接口 CSIA0

#### 17.1 串行接口 CSIA0 的功能

串行接口 CSIA0 有以下三种模式。

### (1) 操作停止模式

在不进行串行通信时可采用此模式,以降低功耗。 需要了解详细信息,可参见 **17.4.1 操作停止模式**。

#### (2) 3线串行 I/O 模式 (可选择 MSB / LSB-first)

该模式采用三条线(一条串行时钟线(SCKA0)和两条串行数据线(SIA0 和 SOA0)),以 8 位单元进行连续数据通信。

在 3 线串行 I/O 模式中数据通信时间可以缩短,因为发送和接收操作可以同步进行。 此外,可以采用 MSB 或者 LSB-first 进行 8 位数据通信,因此该接口可以和任何设备相连。 需要了解详细信息,可参见 **17.4.2 3 线串行 I/O 模式**。

### (3) 具有自动发送/接收功能的 3 线串行 I/O 模式 (可选择 MSB/LSB-first)

该模式采用三条线(一条串行时钟线(SCKAO)和两条串行数据线(SIAO和 SOAO))以8位单元进行连续数据通信。 在此模式中数据通信时间可以缩短,因为发送和接收操作可以同步进行。

此外,可以采用 MSB 或者 LSB-first 进行 8 位数据通信,因此该接口可以和任何设备相连。

不使用软件,串行接口也可以与显示驱动器等进行通信,这是因为串行接口中集成了一个 32 字节的传送缓冲 RAM。此外,还包括在主设备模式下使用的握手引脚(STB0,BUSY0),可方便地与外部 IC 连接。

需要了解详细信息,可参见 17.4.3 具有自动发送/接收功能的 3 线串行 I/O 模式。

串行接口 CSIAO 的特性如下。

- 可选择主设备模式/从设备模式
- 通信数据宽度: 8位
- 可选择 MSB/LSB-first 用于数据通信
- 自动发送/接收功能:

可规定传送字节的个数在1~32之间。

可规定传送间隔(0~63个时钟)

可选择单一通信/重复通信

内部 32 字节缓冲 RAM

- 内置专用波特率发生器 (分频: 6/8/16/32)
- 3线 SOA0: 串行数据输出

 SIA0:
 串行数据输入

 SCKA0:
 串行时钟 I/O

• 具有握手功能的 STB0: 输出选通

BUSY0: 输入忙

- 根据 BUSY0 信号进行移位错误检测
- 发送/接收完成中断: INTACSI

# 17.2 串行接口 CSIA0 的配置

串行接口 CSIA0 由以下硬件组成。

表 17-1 串行接口 CSIA0 的配置

| 项目    | 配置                                                                                                                                                                                                               |  |  |  |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 控制器   | 串行传送控制器                                                                                                                                                                                                          |  |  |  |  |  |
| 寄存器   | 串行 I/O 移位寄存器 0 (SIOA0)                                                                                                                                                                                           |  |  |  |  |  |
| 控制寄存器 | 串行操作模式选择寄存器 0 (CSIMA0)<br>串行状态寄存器 0 (CSIS0)<br>串行触发寄存器 0 (CSIT0)<br>除数选择寄存器 0 (BRGCA0)<br>自动数据传送地址指针指定寄存器 0 (ADTP0)<br>自动数据传送间隔指定寄存器 0 (ADTI0)<br>自动数据传送地址计数寄存器 0 (ADTC0)<br>端口模式寄存器 14 (PM14)<br>端口寄存器 14 (P14) |  |  |  |  |  |



# (1) 串行 I/O 移位寄存器 0 (SIOA0)

该 8 位寄存器以 1 字节传送模式(串行操作模式选择寄存器 0 (CSIMA0)的第 6 位(ATE0) = 0)存储发送/接收数据。 将发送数据写入 SIOA0 以启动通信。此外,在输出通信完成中断请求(INTACSI)后(串行状态寄存器 0(CSIS0)的第 0 位(TSF0) = 0),可通过读取 SIOA0 来接收数据。

可由 8 位存储器操作指令对该寄存器进行读写操作。但当 CSIS0 的第 0 位(TSF0) =1 时,禁止对 SIOA0 进行写操作。

复位信号的产生对该寄存器清零(00H)。

注意事项: 1. 通过写 SIOA0 来启动通信操作。因此,当禁止发送时(CSIMA0 的第 3 位(TXEA0) = 0),可向 SIOA0 写入虚拟数据来启动通信,然后执行接收操作。

2. 当使用自动发送/接收功能时,不要对 SIOA0 进行写操作。

### 17.3 控制串行接口 CSIA0 的寄存器

串行接口 CSIA0 由以下 9个寄存器控制。

- 串行操作模式选择寄存器 0 (CSIMA0)
- 串行状态寄存器 0 (CSIS0)
- 串行触发寄存器 0 (CSIT0)
- •除数选择寄存器 0 (BRGCA0)
- 自动数据传送地址指针指定寄存器 0 (ADTP0)
- 自动数据传送间隔指定寄存器 0 (ADTI0)
- 自动数据传送地址计数寄存器 0 (ADTC0)
- ●端口模式寄存器 14 (PM14)
- ●端口寄存器 14 (P14)

# (1) 串行操作模式选择寄存器 0 (CSIMA0)

该 8 位寄存器用于控制串行通信操作。 可由 1 位或 8 位存储器操作指令设置该寄存器。 复位信号的产生将该寄存器清零(00H)。

#### 图 17-2 串行操作模式选择寄存器 0(CSIMA0)的格式

地址: FF90H 复位后: 00H R/W

| 符号     | <7>    | 6    | 5    | 4       | <3>   | <2>   | 1    | 0 |
|--------|--------|------|------|---------|-------|-------|------|---|
| CSIMA0 | CSIAE0 | ATE0 | ATM0 | MASTER0 | TXEA0 | RXEA0 | DIR0 | 0 |

| CSIAE0 | CSIAO 操作允许/禁止的控制                                                |  |  |  |  |  |  |
|--------|-----------------------------------------------------------------|--|--|--|--|--|--|
| 0      | 禁止 CSIAO 操作(SOAO: 低电平,SCKAO: 高电平),<br>并且异步复位内部电路 <sup>性</sup> 。 |  |  |  |  |  |  |
| 1      | 允许 CSIAO 操作                                                     |  |  |  |  |  |  |

|   | ATE0 | 自动通信操作允许/禁止的控制 |  |  |  |  |  |  |
|---|------|----------------|--|--|--|--|--|--|
| ſ | 0    | 1字节通信模式        |  |  |  |  |  |  |
|   | 1    | 自动通信模式         |  |  |  |  |  |  |

| ATM0 | 自动通信模式的选择                          |  |  |  |  |  |  |
|------|------------------------------------|--|--|--|--|--|--|
| 0    | 单一传送模式(在由 ADTPO 寄存器指定的地址处停止)       |  |  |  |  |  |  |
| 1    | 重复传送模式(传送完成后,对 ADTC0 清零(00H)可恢复传送) |  |  |  |  |  |  |

| MASTER0 | CSIAO 主设备/从设备模式的选择    |
|---------|-----------------------|
| 0       | 从设备模式(与 SCKAO 输入时钟同步) |
| 1       | 主设备模式(与内部时钟同步)        |

| TXEA0 | 对发送操作允许/禁止的控制     |
|-------|-------------------|
| 0     | 禁止发送操作(SOA0: 低电平) |
| 1     | 允许发送操作            |

| RXEA0 | 对接收操作允许/禁止的控制 |
|-------|---------------|
| 0     | 禁止接收操作        |
| 1     | 允许接收操作        |

| DIR0 | 对起始位的选择 |
|------|---------|
| 0    | MSB     |
| 1    | LSB     |

注: 对自动数据传送地址计数寄存器 0(ADTC0)、串行触发寄存器 0(CSIT0)、串行 I/O 移位寄存器 0 (SIOA0) 和串行状态寄存器 0 (CSIS0) 的第 0 位 (TSF0) 进行复位。

### 注意事项: 1. 当 CSIAE0 = 0 时,不能访问缓冲 RAM。

- 2. 当 CSIAE0 的值从 1 变为 0 时,上面"注"中提到的寄存器和位将被异步初始化。要再一次设置 CSIAE0 的值等于 1,必须重新设置这些已初始化的寄存器。
- 3. 当 CSIAE0 的值从 1 变为 0, 又被重新置 1 时,不能保证是否能够保持缓冲 RAM 的值。

### (2) 串行状态寄存器 0 (CSIS0)

该 8 位寄存器用于选择基本时钟、控制通信操作,并指示串行接口 CSIA0 的状态。可由 1 位或 8 位存储器操作指令设置该寄存器。但当第 0 位 (TSF0) =1 时禁止重写 CSIS0。复位信号的产生将该寄存器清零 (00H)。

### 图 17-3 串行状态寄存器 0 (CSIS0) 的格式 (1/2)

地址: FF91H 复位后: 00H R/W<sup>±1</sup>

符号 7 6 4 3 2 0 1 CSIS0 CKS00 STBE0 BUSYE0 BUSYLV0 ERRE0 ERRF0 TSF0

| CKS00 | 基本时钟(fw)选择   |              |              |               |               |
|-------|--------------|--------------|--------------|---------------|---------------|
|       |              | fprs = 2 MHz | fprs = 5 MHz | fprs = 10 MHz | fprs = 20 MHz |
| 0     | <b>f</b> PRS | 2 MHz        | 5 MHz        | 10 MHz        | 20 MHz        |
| 1     | fprs/2       | 1 MHz        | 2.5 MHz      | 5 MHz         | 10 MHz        |

| STBE0 ** 3, 4 | 允许/禁止输出选通 |
|---------------|-----------|
| 0             | 禁止输出选通    |
| 1             | 允许输出选通    |

| BUSYE0 | 允许/禁止忙信号检测              |
|--------|-------------------------|
| 0      | 禁止忙信号检测(BUSY0 引脚的输入被忽略) |
| 1      | 允许忙信号检测,并且通过执行忙信号进行通信等待 |

| BUSYLV0 <sup>2</sup> 44 | 忙信号活动电平的设置 |
|-------------------------|------------|
| 0                       | 低电平        |
| 1                       | 高电平        |

#### **注: 1.** 第 0 和 1 位是只读的。

- 2. STBE0 仅在主设备模式下有效。
- **3.** 当 STBE0 = 1 时,无论自动数据传送间隔指定寄存器 0(ADTI0)的设置值是多少,在字节传送期间都需要额外的两个传送时钟。即,如果 ADTI0 = 00H,传送 1 字节需要 10 个传送时钟。
- 4. 在通过忙输入检测位错误时,将检测由 BUSYLV0 指定的活动电平。

#### 注意事项: 第7位必须被清零。

**备注:** fprs: 外部硬件时钟频率

# 图 17-3 串行状态寄存器 0 (CSIS0) 的格式(CSIS0) (2/2)

|   | ERRE0** | 允许/禁止位错误检测 |
|---|---------|------------|
|   | 0       | 禁止错误检测     |
| Ī | 1       | 允许错误检测     |

| ERRF0 | 位错误检测标志                                                     |  |  |  |  |  |  |  |  |
|-------|-------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 0     | 申                                                           |  |  |  |  |  |  |  |  |
| 1     | 检测到位错误(当 ERRE0=1 时,在数据位传送期间,检测到由 BUSY0 引脚输入的、BUSYLV0 指定的电平) |  |  |  |  |  |  |  |  |

| TSF0 | 发送状态检测标志                                                                                                                                      |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | <ul> <li>串行操作模式选择寄存器 0(CSIMA0)的第7位(CSIAE0)=0时</li> <li>复位输入时</li> <li>指定的传送操作结束时</li> <li>将串行触发寄存器 0(CSIT0)的第1位(ATSTP0)置1,以停止传送操作时</li> </ul> |
| 1    | 指定传送从传送开始到结束                                                                                                                                  |

注:即使当BUSYE0=0时ERRE0设置也有效。

注意事项: 传送期间(TSF0 = 1),禁止改写串行操作模式选择寄存器 0(CSIMA0)、串行状态寄存器 0(CSIS0)、除数选择寄存器 0(BRGCA0)、自动数据传送地址指针指定寄存器 0(ADTP0)、自动数据传送间隔指定寄存器 0(ADTI0)和串行 I/O 移位寄存器 0(SIOA0)。但可以对这些寄存器进行读取和重新写入相同的值。此外传送期间可以重写缓冲 RAM。

# (3) 串行触发寄存器 0 (CSIT0)

该8位寄存器用于控制缓冲RAM与串行I/O移位寄存器0(SIOA0)之间的自动数据传送的执行/停止操作。可由1位或8位存储器操作指令设置该寄存器。当串行操作模式选择寄存器0(CSIMA0)的第6位(ATE0)=1时可以对该寄存器进行设置。

复位信号的产生将该寄存器清零(00H)。

# 图 17-4 串行触发寄存器 0 (CSIT0) 的格式

| 地址: FF92H |   | 复位后: 00H | R/W |   |   |   |        |        |
|-----------|---|----------|-----|---|---|---|--------|--------|
| 符号        | 7 | 6        | 5   | 4 | 3 | 2 | <1>    | <0>    |
| CSIT0     | 0 | 0        | 0   | 0 | 0 | 0 | ATSTP0 | ATSTA0 |
|           |   |          |     |   |   |   |        |        |

| ATSTP0 | 停止自动数据传送操作 |
|--------|------------|
| 0      | -          |
| 1      | 停止自动数据传送操作 |

| ATSTA0 | 启动自动数据传送操作 |
|--------|------------|
| 0      | -          |
| 1      | 启动自动数据传送操作 |

注意事项: 1. 即使 ATSTP0 或 ATSTA0 等于 1, 自动传送的启动/停止操作也要等到 1 字节传送完成时才能进行。

- 2. 产生中断信号 INTACSI 后, ATSTP0 和 ATSTA0 自动变为 0。
- 3. 在停止自动数据传送操作后,将传送停止时的数据地址保存在自动数据传送地址计数寄存器 0 (ADTC0)中。但是,由于没有重新启动自动数据传送的功能,当 ATSTP0 = 1 使传送停止时,重新设置这些寄存器后,将 ATSTA0 置 1 启动自动数据传送操作。

# (4) 除数选择寄存器 0 (BRGCA0)

该 8 位寄存器用于选择 CSIAO 的基本时钟分频。

可由 8 位存储器操作指令设置该寄存器。但当串行状态寄存器 0(CSISO)的第 0 位(TSF0)=1 时,禁止重写 BRGCA0。

复位信号的产生将该寄存器设置为 03H。

# 图 17-5 除数选择寄存器 0 (BRGCA0) 的格式

地址: FF93H 复位后: 03H R/W

| 符号     | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
|--------|---|---|---|---|---|---|---------|---------|
| BRGCA0 | 0 | 0 | 0 | 0 | 0 | 0 | BRGCA01 | BRGCA00 |

| BRGCA01 | BRGCA00 |                   |            | CSIAO 基本时钟(fw)除数选择 |              |            |                       |                        |  |
|---------|---------|-------------------|------------|--------------------|--------------|------------|-----------------------|------------------------|--|
|         |         |                   | fw = 1 MHz | fw = 2 MHz         | fw = 2.5 MHz | fw = 5 MHz | fw = 10 MHz           | fw=20 MHz <sup>注</sup> |  |
| 0       | 0       | fw/6              | 166.67 kHz | 333.3 kHz          | 416.67 kHz   | 833.33 kHz | 1.67 MHz <sup>注</sup> | 禁止设置                   |  |
| 0       | 1       | fw/2 <sup>3</sup> | 125 kHz    | 250 kHz            | 312.5 kHz    | 625 kHz    | 1.25 MHz <sup>推</sup> | 禁止设置                   |  |
| 1       | 0       | fw/2 <sup>4</sup> | 62.5 kHz   | 125 kHz            | 156.25 kHz   | 312.5 kHz  | 625 kHz               | 1.25 MHz               |  |
| 1       | 1       | fw/2 <sup>5</sup> | 31.25 kHz  | 62.5 kHz           | 78.125 kHz   | 156.25 kHz | 312.5 kHz             | 625 kHz                |  |

注: 仅当 4.0 V ≤ VDD ≤ 5.5 V 时可以设置

注意事项: 设置传送时钟时, 必须满足以下条件。

• 4.0 V ≤ V<sub>DD</sub> ≤ 5.5 V: ≤1.67 MHz • 2.7 V ≤ V<sub>DD</sub> < 4.0 V: ≤833.33 kHz

**备注:** fw: 由 CSISO 寄存器的 CKSOO 位选择的基本时钟频率

fprs: 外部硬件时钟频率

#### (5) 自动数据传送地址指针指定寄存器 0 (ADTP0)

该 8 位寄存器用于指定自动传送期间(串行操作模式选择寄存器 0(CSIMA0)的第 6 位(ATE0)=1)结束传送时的缓冲 RAM 的地址。

可由8位存储器操作指令设置该寄存器。但在传送期间(TSF0=1),禁止重写ADTP0。

在 78K0/KF2 中,由于包含 32 字节缓冲 RAM,可指定  $00H\sim1FH$  之间的值。

# **举例:** 当 ADTP0 = 07H

地址为 FA00H ~ FA07H 的 8 字节数据被传送。

在重复传送模式中(CSIMAO 的第 5 位(ATMO)=1),重复执行传送操作,一直执行到 ADTPO 指定的地址处。

# **举例:** ADTP0 = 07H (重复传送模式)

重复执行传送操作,即 FA00H  $\sim$  FA07H、FA00H  $\sim$  FA07H, ... 。

#### 图 17-6 自动数据传送地址指针指定寄存器 0 (ADTP0) 的格式

地址: FF94H 复位后: 00H R/W

| 符号    | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0      |
|-------|---|---|---|--------|--------|--------|--------|--------|
| ADTP0 | 0 | 0 | 0 | ADTP04 | ADTP03 | ADTP02 | ADTP01 | ADTP00 |

#### 注意事项: 第7~5位必须被清零。

传送结束缓冲 RAM 地址与 ADTPO 的设置值之间的关系如下所示。

表 17-2 传送结束缓冲 RAM 地址与 ADTP0 的设置值之间的关系

| 传送结束时的缓冲 RAM 地址 | ADTP0 的设置值 |
|-----------------|------------|
| FAxxH           | xxH        |

备注: xx: 00 ~ 1F

#### (6) 自动数据传送间隔指定寄存器 0 (ADTIO)

该8位寄存器用于指定自动数据传送时(CSIMA0的第6位(ATE0)=1)字节数据传送的间隔时间。在主设备模式中(CSIMA0的第4位(MASTER0)=1)设置该寄存器(在从设备模式中不必设置)。在1字节通信模式中(CSIMA0的第6位(ATE0)=0)设置也有效。在1字节通信结束并经历了间隔时间(由ADTI0指定)后,将输出一个中断请求信号(INTACSI)。间隔时间的时钟个数可设置为0~63之间。可由8位存储器操作指令设置该寄存器。但当CSIS0的第0位(TSF0)=1时,禁止重写ADTI0。

#### 图 17-7 自动数据传送间隔指定寄存器 0 (ADTIO) 的格式

| 地址: FF | 95H | 复位后: 00H | R/W    |        |        |        |        |        |
|--------|-----|----------|--------|--------|--------|--------|--------|--------|
| 符号     | 7   | 6        | 5      | 4      | 3      | 2      | 1      | 0      |
| ADTI0  | 0   | 0        | ADTI05 | ADTI04 | ADTI03 | ADTI02 | ADTI01 | ADTI00 |

注意事项: 由于串行状态寄存器 0(CSIS0)的第 5 位 (STBE0)和第 4 位 (BUSYE0)的设置优先于 ADTI0 的设置,因此即使 ADTI0 被清零(00H)时,也将产生基于 STBE0 和 BUSYE0 设置的间隔时间。

举例: 当 ADTI0=00H 且没有产生忙信号时的间隔时间

<1> 当 STBE0 = 1, BUSYE0 = 0: 产生两个串行时钟的间隔时间

<2> 当 STBE0 = 0, BUSYE0 = 1: 产生一个串行时钟的间隔时间

<3> 当 STBE0 = 1, BUSYE0 = 1: 产生两个串行时钟的间隔时间

因此,如果要执行无等待传送操作,必须对 STBE0 和 BUSYE0 清零。

指定的间隔时间为串行时钟(由除数选择寄存器0(BRGCA0)规定)乘以一个整数。

举例: 当 ADTI0 = 03H



#### (7) 自动数据传送地址计数寄存器 0 (ADTC0)

该寄存器用于指示自动传送期间缓冲 RAM 的地址。当自动传送操作停止时,可通过读取 ADTCO 获得传送停止时的数据位置。

可由8位存储器操作指令读取该寄存器。

复位信号的产生将该寄存器清零(00H)。但当串行状态寄存器 0 (CSISO)的第 0 位(TSF0) = 1 时禁止读取 ADTCO。

#### 图 17-8 自动数据传送地址计数寄存器 0 (ADTC0)的格式

地址: FF97H 复位后: 00H R

| 符号    | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0      |
|-------|---|---|---|--------|--------|--------|--------|--------|
| ADTC0 | 0 | 0 | 0 | ADTC04 | ADTC03 | ADTC02 | ADTC01 | ADTP00 |

#### (8) 端口模式寄存器 14 (PM14)

该寄存器用于按位设置端口14的输入/输出操作模式。

当 P142/SCKA0 用于串行接口的时钟输出时,对 PM142 清零并对 P142 的输出锁存器置 1。

当 P144/SOA0 和 P145/STB0 用于串行接口的数据输出或选通输出时,将 PM144、PM145 和 P144 与 P145 的 输出锁存值清零。

当 P141/BUSY0, P142/SCKA0, and P143/SIA0 用于串行接口的忙信号输入、时钟输入或数据输入时,将 PM141、PM142 和 PM143 置 1。此时,P141、P142 和 P143 的输出锁存器的值可以为 0 或 1。可由 1 位或 8 位存储器操作指令设置 PM14。

复位信号的产生将该寄存器设置为 FFH。

#### 图 17-9 端口模式寄存器 14 (PM14) 的格式

地址: FF2EH 复位后: FFH R/W

| 符号   | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |
|------|---|---|-------|-------|-------|-------|-------|-------|
| PM14 | 1 | 1 | PM145 | PM144 | PM143 | PM142 | PM141 | PM140 |

| PM14n | P14n 引脚 I/O 模式选择 (n = 0 ~ 5) |
|-------|------------------------------|
| 0     | 输出模式 (输出缓冲器打开)               |
| 1     | 输入模式 (输出缓冲器关闭)               |

## 17.4 串行接口 CSIA0 的操作

串行接口 CSIA0 有以下三种模式。

- 操作停止模式
- · 3线串行 I/O 模式
- 具有自动发送/接收功能的3线串行I/O模式

#### 17.4.1 操作停止模式

在此模式下,不能进行串行通信,可降低功耗。此外,P142/SCKAO、P143/SIAO 和 P144/SOAO 可作为一般的 I/O 端口引脚使用。

# (1) 使用的寄存器

由串行操作模式选择寄存器 0(CSIMA0)设置操作停止模式。将 CSIMA0 的第 7 位(CSIAE0)清零,可以设置该模式。

#### (a) 串行操作模式选择寄存器 0 (CSIMA0)

该 8 位寄存器用于控制串行通信操作。 可由 1 位或 8 位存储器操作指令设置该寄存器。 复位信号的产生将该寄存器清零(00H)。

地址: FF90H 复位后: 00H R/W

CSIMA0

| <7>    | 6    | 5    | 4       | <3>   | <2>   | 1    | 0 |
|--------|------|------|---------|-------|-------|------|---|
| CSIAE0 | ATE0 | ATM0 | MASTER0 | TXEA0 | RXEA0 | DIR0 | 0 |

| CSIAE0 | 对 CSIA0 操作允许/禁止的控制                               |
|--------|--------------------------------------------------|
| 0      | 禁止 CSIA0 操作(SOA0: 低电平,SCKA0: 高电平),并且<br>异步复位内部电路 |

#### 17.4.2 3线串行 I/O 模式

当串行操作模式选择寄存器 0(CSIMA0)的第 6 位(ATE0)被清零时,执行 1 字节数据发送/接收操作。该模式采用时钟串行接口连接外部 IC 和显示控制器。

该模式中使用三条线进行通信: 串行时钟(SCKAO)、串行输出(SOAO)和串行输入(SIAO)线。

#### (1) 使用的寄存器

- · 串行操作模式选择寄存器 0 (CSIMA0) \*1
- 串行状态寄存器 0 (CSIS0) \*2
- · 除数选择寄存器 0 (BRGCA0)
- · 端口模式寄存器 4 (PM14)
- · 端口寄存器 14 (P14)
- 注: 1. 使用第 7、6 和 4  $\sim$  1 位 (CSIAE0, ATE0, MASTER0, TXEA0, RXEA0 和 DIR0)。设置第 5 位 (ATM0) 无效。
  - 2. 仅使用第6位(CKS00)和第0位(TSF0)。

在 3 线串行 I/O 模式中操作设置的基本步骤如下。

- <1> 设置 CSISO 寄存器的第 6 位 (CKS00) (参见 图 17-3) <sup>注1</sup>
- <2> 设置 BRGCA0 寄存器 (参见 图 17-5) <sup>注1</sup>。
- <3> 设置 CSIMA0 寄存器的第 4 ~ 1 位(MASTERO, TXEA0, RXEA0 和 DIRO)(参见 图 17-2)。
- <4> 设置 CSIMA0 寄存器的第7位(CSIAE0) =1,并将第6位(ATE0)清零。
- <5> 将数据写入串行 I/O 移位寄存器 0(SIOA0)。 → 启动数据发送/接收操作 $^{\pm 2}$ 。
- 注: 1. 选择从设备模式时(MASTER0=0),不能设置该寄存器。
  - 2. 对 SIOA0 写入虚拟数据仅用于接收。

注意事项: 在设置端口模式寄存器和端口寄存器时, 要考虑与通信另一方的关系。

寄存器设置与引脚之间的关系如下。

# 表 17-3 寄存器设置与引脚之间的关系

| CSIAE0 | ATE0 | MASTER0 | PM143            | P143              | PM144            | P144            | PM142            | P142             | 串行 I/O 移位     | 串行时钟计       |               | 引脚功能          |                |
|--------|------|---------|------------------|-------------------|------------------|-----------------|------------------|------------------|---------------|-------------|---------------|---------------|----------------|
|        |      |         |                  |                   |                  |                 |                  |                  | 寄存器 0 的<br>操作 | 数器的操作<br>控制 | SIA0/<br>P143 | SOA0/<br>P144 | SCKA0/<br>P142 |
| 0      | ×    | ×       | x <sup>i±1</sup> | x <sup>推1</sup>   | x <sup>i±1</sup> | x <sup>±1</sup> | x <sup>i±1</sup> | x <sup>i±1</sup> | 停止操作          | 清零          | P143          | P144          | P142           |
| 1      | 0    | 0       | 1 <sup># 2</sup> | x <sup>it 2</sup> | 0 *± 3           | 0 #± 3          | 1                | ×                | 允许操作          | 计数操作        | SIA0 *2       | SOA0 **3      | SCKA0<br>(输入)  |
|        |      | 1       |                  |                   |                  |                 | 0                | 1                |               |             |               |               | SCKA0<br>(输出)  |

**注:** 1. 可用作端口引脚。

2. 仅执行发送时,可以用作 P143。将 CSIMA0 的第 2 位 (RXEA0) 清零。

3. 仅执行接收时,可以用作 P144。将 CSIMA0 的第 3 位(TXEA0)清零。

**备注:** ×: 不必考虑

CSIAE0: 串行操作模式选择寄存器 0 (CSIMA0) 的第 7 位

ATEO: CSIMA0 的第 6 位 MASTERO: CSIMA0 的第 4 位 PM14×: 端口模式寄存器 P14×: 端口输出锁存器

#### (2) 1字节发送/接收通信操作

#### (a) 1字节发送/接收

当串行操作模式选择寄存器 0(CSIMA0)的第 7 位(CSIAE0)和第 6 位(ATE0)分别 = 1、0 时,如果通信数据已被写入串行 I/O 移位寄存器 0(SIOA0)中,则在  $\overline{SCKA0}$  的下降沿通过 SOA0 引脚同步输出数据,并在之后 1个时钟的上升沿将数据同步存入 SIOA0 中。

数据发送和数据接收操作可同时进行。

如果只执行接收操作,则只能通过向 SIOA0 写入虚拟值才可启动通信。

在完成1字节通信后,会产生一个中断请求信号(INTACSI)。

在1字节发送/接收操作中,CSIMA0的第5位(ATM0)设置无效。

必须在确认 CSIS0 的第 0 位 (TSF0) = 0 后读取数据。



图 17-10 3线串行 I/O 模式的时序

注意事项: 通过写 SIOA0 可使 SOA0 引脚变为低电平。

# (b) 数据格式

在数据格式中,在  $\overline{SCKA0}$  下降沿同步修改数据,如下所示。 数据宽度恒为 8 位。通过设置  $\overline{CSIMA0}$  的第 1 位( $\overline{DIR0}$ )可切换数据通信的方向。

# 图 17-11 发送/接收数据的格式

# (a) MSB-first (DIR0 位 = 0)



# (b) LSB-first (DIR0 位 = 1)



#### (c) 切换 MSB/LSB 作为起始位

图 17-12 显示了串行 I/O 移位寄存器 0 (SIOA0) 和内部总线的配置。如图中所示,可对 MSB/LSB 进行反向读/写。

根据 CSIMA0 的第 1 位(DIR0)可规定: 切换 MSB/LSB 作为起始位。



图 17-12 传送位次序切换电路

通过对写入 SIOA0 的数据位次序进行切换,可实现起始位的切换。SIOA0 的移位次序保持不变。这样,MSB-first 与 LSB-first 之间的切换操作必须在将数据写入移位寄存器之前进行。

# (d) 启动通信

在满足以下两个条件时,将通信数据写入串行 I/O 移位寄存器 0(SIOA0),可以启动串行通信。

- 串行接口 CSIA0 操作控制位(CSIAE0) = 1
- 没有进行串行通信。

注意事项: 如果将数据写入 SIOA0 后设置 CSIAE0 =1,则不能启动通信。

在8位通信结束时,串行通信自动停止,并设置中断请求标志(ACSIIF)。

#### 17.4.3 具有自动发送/接收功能的 3 线串行 I/O 模式

在此模式中,当 CSIMA0 的第 6 位 (ATE0) =1 时,不使用软件也可以对多达 32 字节的数据进行发送/接收。只有当数据的字节数提前存于 RAM 中,才能在启动通信后发送该数据,并且只有设置了字节数的数据才能被接收,并存于RAM 中。

此外,当使用主设备且该模式支持通过硬件产生握手信号(STBO 和 BUSYO)功能时,可连续发送/接收数据。因此,很容易实现与外部 IC(例如 OSD(屏幕显示)IC)和 LCD 控制器/驱动器的连接。

# (1) 使用的寄存器

- · 串行操作模式选择寄存器 0 (CSIMA0)
- · 串行状态寄存器 0 (CSIS0)
- · 串行触发寄存器 0 (CSIT0)
- · 除法选择寄存器 0 (BRGCA0)
- · 自动数据传送地址指针指定寄存器 0 (ADTP0)
- · 自动数据传送间隔指定寄存器 0 (ADTI0)
- · 端口模式寄存器 14 (PM14)
- · 端口寄存器 14 (P14)

寄存器设置与引脚之间的关系如下。

注意事项: 当数据写入缓冲 RAM 时,可能会产生一个等待状态。如需了解详细内容,可参见第三十二章 等待注意事项。

# 表 17-4 寄存器设置与引脚之间的关系

|                                                            | _                               |                                  |                                                        |                                |      |                                                                                                               |            |
|------------------------------------------------------------|---------------------------------|----------------------------------|--------------------------------------------------------|--------------------------------|------|---------------------------------------------------------------------------------------------------------------|------------|
|                                                            | BUSY0/                          | P141                             | P141                                                   | P141                           |      | P141                                                                                                          | STB0 BUSY0 |
|                                                            | STB0/                           | P145                             | P145                                                   | P145                           |      | P145                                                                                                          | STB0       |
| 引脚功能                                                       | SCKA0/                          | P142                             | P142                                                   | SCKA0                          | (イ編) | SCKA0 P145 P141                                                                                               | (田編        |
| 引展                                                         | SOA0/                           | P144                             | P143   P144   P142   P145   P141                       | *3 SCKA0 P145 P141             |      | 100                                                                                                           | <u> </u>   |
|                                                            | SIA0/ SOA0/ SCKA0/ STB0/ BUSY0/ | P143   P144   P142   P145   P141 | P143                                                   | #2<br>SIA0                     |      |                                                                                                               |            |
| 串行时钟                                                       | 计数器的                            | 操作控制                             | 清零                                                     | 十巻梅佐                           |      |                                                                                                               |            |
| 143 PM144 P144 PM142 P142 PM145 PM145 PM141 P141 串行 I/O 移位 | 寄存器 0                           | 时架作                              | (#1   X#1   X#1   X#1   X#1   X#1   X#1   X#1     停止操作 | × X * 1 X * 1 X * 1 X * 1 允许操作 |      |                                                                                                               |            |
| P141                                                       |                                 |                                  | × <sup>₩</sup> 1                                       | X<br>和                         |      | × <sup>#1</sup>                                                                                               | ×          |
| PM141                                                      |                                 |                                  | X#1                                                    | X                              |      | × <sup>#1</sup>                                                                                               | 1          |
| P145                                                       |                                 |                                  | Y 在 Y                                                  | X#1                            |      | imes#1                                                                                                        | 0 0        |
| PM145                                                      |                                 |                                  | ×#1                                                    | :**X                           |      | $1 \left  \times^{\text{£1}} \right  \times^{\text{£1}} \left  \times^{\text{£1}} \right  \times^{\text{£1}}$ | 0          |
| P142                                                       |                                 |                                  | X#7                                                    | ×                              |      | 1                                                                                                             |            |
| PM142                                                      |                                 |                                  | X<br>和<br>Y                                            | 1                              |      | 0                                                                                                             |            |
| P144                                                       |                                 |                                  | X#1                                                    | 0                              |      |                                                                                                               |            |
| PM144                                                      |                                 |                                  | ×#1                                                    | 0                              |      |                                                                                                               |            |
| ۵                                                          |                                 |                                  | 1 ## X                                                 | ×                              |      |                                                                                                               |            |
| PM143                                                      |                                 |                                  | × <sup>#1</sup>                                        | -                              |      |                                                                                                               |            |
| ERREO                                                      |                                 |                                  | X<br>和                                                 | 1/0                            |      | 0/1                                                                                                           | 0/1        |
| <b>BUSYE</b> 0                                             |                                 |                                  | X#1                                                    | X#1                            |      | 0                                                                                                             | 1          |
| MASTERO STBEO BUSYEO ERREO PM143                           |                                 |                                  | ×                                                      | T 本 ×                          |      | 0                                                                                                             | 1          |
| MASTERO                                                    |                                 |                                  | ×                                                      | 0                              |      | 1                                                                                                             |            |
| CSIAEO ATEO                                                |                                 |                                  | ×                                                      | -                              |      |                                                                                                               |            |
| CSIAE0                                                     |                                 |                                  | 0                                                      | 1                              |      |                                                                                                               |            |

可用作端口功能。 洪

在只执行发送操作时可用作 P143。CSIMA0 的第 2 位(RXEA0)被清零。 رن ب

在只执行接收操作时,可用作 P144。将 CSIMA0 的第 3 位(TXEA0)清零。

不必考虑 备注: 串行操作模式选择寄存器 0 (CSIMA0) 的第7位。 CSIAE0:

CSIMA0的第6位 ATE0:

CSIMA0的第4位 MASTER0:

串行状态寄存器 0 (CSIS0) 的第5位

CSIS0 的第 4位 BUSYE0: STBE0:

CSISO 的第2位 ERRE0: 端口模式寄存器 端口输出锁存器 PM14x: P14x:

#### ★ (2) 自动发送/接收数据的设置

以下是作为主设备连续发送/接收数据的过程示例。

- <1> 通过设置 CSIMA0 的第7位(CSIAE0)=1,允许 CSIA0 操作(此时可以访问缓冲 RAM)。
- <2> 通过使用串行状态寄存器 0 (CSIS0)设置串行时钟
- <3> 通过使用除数选择寄存器(BRGCA0)设置串行时钟的分频比,并指定通信速率。
- <4> 从最低有效地址 FA00H 开始一直到 FA00H,将要发送的数据连续写入缓冲 RAM。从最低地址向高地址 发送数据。
- <5> 将"发送数据项的个数 1"赋给自动数据传送地址指针指定寄存器 0 (ADTP0)。
- <6> 设置 CSIMAO 的第6位 (ATEO)和第4位(MASTERO),用于在自动通信模式下选择主设备操作。
- <7> 设置 CSIMA0 的第 3 位(TXEA0)和第 2 位(RXEA0) =1,允许发送/接收。
- <8> 将数据的发送间隔赋给自动数据传送间隔指定寄存器 (ADTIO)。
- <9> 当串行触发寄存器 0 (CSIT0)的第 0 位(ATSTA0) =1 时启动自动发送/接收操作。

#### 注意事项: 在设置端口模式寄存器和端口寄存器时, 要考虑与通信另一方之间的关系。

操作 <1>  $\sim$  <9>执行以下过程。

- 由自动数据传送地址计数寄存器 0(ADTC0)指定的缓冲 RAM 数据被传送到 SIOA0 中后,开始执行发送操作(即启动自动发送/接收操作)。
- 将接收的数据写入缓冲 RAM(由 ADTC0 指定地址)。
- ADTC0 递增,并执行下一个数据的发送/接收操作。数据的发送/接收操作一直持续到 ADTC0 的递增输出值与自动数据传送地址指针指定寄存器 0 (ADTP0) 的值相匹配为止(停止自动发送/接收操作)。但如果 CSIMA0 的第 5 位 (ATM0) =1 (重复模式),则在 ADTP0 与 ADTC0 匹配后 ADTC0 被清零。然后启动重复发送/接收操作。
- 当结束自动发送/接收操作时,产生中断请求(INTACSI)并且将 CSISO 的第 0 位(TSF0)清零。
- 如果要继续发送下一组数据,将新数据赋给缓冲 RAM,并将"要发送数据的个数 1"赋给 ADTP0。 在设置数据个数后,设置 ATSTA0 =1。

#### (3) 自动发送/接收通信操作

#### (a) 自动发送/接收模式

使用缓冲 RAM 执行自动发送/接收操作。

执行(2)自动发送/接收数据的设置,在 SCKAO 下降沿将存于缓冲 RAM 中的数据通过 SIOAO 寄存器从 SOAO 引脚同步输出。

然后通过 SIOA0 寄存器,在 SCKA0 上升沿将接收的数据同步存于缓冲 RAM 中。

如果串行状态寄存器 0 (CSISO) 的第 0 位(TSFO) =1,且满足以下任何一个条件时,数据传送操作结束。

- 通信停止: 通过对 CSIMAO 的第7位 (CSIAEO) 清零,进行复位。
- 通信暂停: 设置 CSIT0 的第 1 位 (ATSTP0) =1,完成 1 字节传送操作。
- 位移位错误: 当 CSISO 的第 1 位 (ERRFO) 和第 2 位 (ERREO) = 1 时, 1 字节传送操作完成。
- 由 ADTP0 规定的范围的传送操作结束。

此时,会产生中断请求信号(INTACSI),CSIAE0 = 0 时除外。

如果传送操作在中途被停止,则无法从剩余数据开始继续进行传送。应该读取自动数据传送地址计数寄存器 0(ADTC0),以确定有多少数据已经被传送,然后执行**(2)自动发送/接收数据的设置**,再次启动传送操作。

此外,当不执行忙控制和选通控制时,BUSY0/BUZ/INTP7/P141 和 STB0/P145 可作为通用 I/O 端口引脚使用。

图 17-13 显示了自动发送/接收模式中的操作时序,图 17-14 显示了其操作流程图。而图 17-15 和 17-16 则 为发送/接收 6 字节数据时内部缓冲 RAM 的操作。

# 图 17-13 自动发送/接收模式操作时序



- 注意事项: 1. 由于在自动发送/接收模式中,是在发送/接收 1 字节后将数据写入内部缓冲 RAM,或从内部缓冲 RAM 中读取数据,因此在下一个发送/接收之前插入一个间隔。对缓冲 RAM 的读写操作与 CPU 操作同时进行时,间隔时间取决于自动数据传送间隔指定寄存器 0 (ADTIO)以及串行状态寄存器 0 (CSISO)的第 5 和 4 位 (STBEO, BUSYEO)的值 (参见 (5)自动发送/接收的间隔时间)。
- 2. 如果在间隔时间内,CPU 对缓冲 RAM 的访问与串行接口 CSIA0 对缓冲 RAM 的访问冲突,那么由自动数据传送间隔指定寄存器 0 (ADTIO)指定的间隔时间可能会被延长。

备注: ACSIIF: 中断请求标志

TSF0: 串行状态寄存器 0 (CSIS0) 的第 0 位

图 17-14 自动发送/接收模式流程图



CSIAE0: 串行操作模式选择寄存器 0 (CSIMAO)的第7位

ADTI0: 自动数据传送间隔指定寄存器 0

ATSTA0: 串行触发寄存器 0 (CSIT0) 的第 0 位

SIOA0: 串行 I/O 移位寄存器 0

 ADTC0:
 自动数据传送地址计数寄存器 0

 TSF0:
 串行状态寄存器 0 (CSIS0) 的第 0 位

**注:** 当数据写入缓冲 RAM 时,可能会产生一个等待状态。如需了解详细内容,可参见**第三十二章 等待注意事项**。

在自动发送/接收模式中,当进行 6 字节发送/接收时(ATM0 = 0,RXEA0 = 1,TXEA0 = 1),内部缓冲 RAM 的操作如下。

#### (i) 启动发送/接收操作(参见图 17-15)

- <1> 当串行触发寄存器 0 (CSIT0) 的第 0 位 (ATSTA0) =1 时,将发送数据 1 (T1) 从内部缓冲 RAM 传送到 SIOA0 中,并启动发送/接收操作。
- <2> 当第1个字节发送完成后,将接收数据1(R1)从SIOA0传送到缓冲RAM中,而自动数据传送地址计数寄存器0(ADTC0)的值递增。
- <3> 然后再将发送数据 2(T2)从内部缓冲 RAM 传送到 SIOA0中。

# 图 17-15 在自动发送/接收模式下内部缓冲 RAM 的操作 (启动发送/接收) (1/2)

#### <1> 启动第1个字节的发送/接收操作



# 图 17-15 在自动发送/接收模式下内部缓冲 RAM 的操作 (启动发送/接收) (2/2)

#### <2> 结束第1个字节的发送/接收操作



<3> 启动第2个字节的发送/接收操作



# (ii) 发送/接收操作完成(参见图 17-16 )

- <1> 在发送完第 6 个字节时,将接收数据 6(R6)从 SIOA0 传送到内部缓冲 RAM 中,并且 ADTC0 递增。
- <2> 当 ADPT0 与 ADTC0 匹配时,自动发送/接收操作结束,并设置中断请求标志(ACSIIF)(产生 INTACSI)。将 ADTC0 和串行状态寄存器 0 (CSISO)的第 0 位(TSF0)清零(0)。

# 图 17-16 在自动发送/接收模式下内部缓冲 RAM 的操作 (发送/接收操作结束)

# <1> 第6个字节发送/接收结束



# <2> 自动发送/接收操作结束



# (b) 自动发送模式

此模式用于发送指定个数的8位数据。

当串行操作模式选择寄存器 0 (CSIMA0) 的第 7、6、3 位 (CSIAE0、ATE0、TXEA0) 均为 1 时,设置串行触发寄存器 0 (CSIT0) 的第 0 位 (ATSTA0) =1,启动串行通信操作。

当最后一个字节发送完时,设置中断请求标志(ACSIIF)。也可由串行状态寄存器 0 (CSIS0)的第 0 位 (TSF0)判断自动发送和接收操作是否结束。

如果不执行接收操作、忙控制和选通控制,则 SIA0/P143、BUSY0/BUZ/INTP7/P141 和 STB0/P145 可作为通用 I/O 端口引脚使用。

图 17-17 显示了自动发送模式的操作时序,图 17-18 显示了其操作流程图。

# 图 17-17 自动发送模式操作时序



注意事项: 1. 由于在自动发送模式中,是在发送完 1 字节后从内部缓冲 RAM 中读取数据,因此在下一个发送之前插入一个间隔。对缓冲 RAM 的读操作与 CPU 操作同时进行时,间隔时间取决于自动数据传送间隔指定寄存器 0 (ADTIO) 以及串行状态寄存器 0 (CSISO) 的第 5 和 4 位 (STBEO, BUSYEO) 的值(参见(5)自动发送/接收的间隔时间)。

2. 如果在间隔时间内,CPU 对缓冲 RAM 的访问与串行接口 CSIA0 对缓冲 RAM 的访问冲突,那么由自动数据传送间隔指定寄存器 0(ADTI0)指定的间隔时间可能会被延长。

**备注:** ACSIIF: 中断请求标志

TSF0: 串行状态寄存器 0 (CSISO) 的第 0 位

图 17-18 自动发送模式的流程图



CSIAE0: 串行操作模式选择寄存器 0 (CSIMA0)的第7位

 ADTP0:
 自动数据传送地址指针指定寄存器 0

 ADTI0:
 自动数据传送间隔指定寄存器 0

 ATSTA0:
 串行触发寄存器 0 (CSIT0) 的第 0 位

SIOA0: 串行 I/O 移位寄存器 0

 ADTC0:
 自动数据传送地址计数寄存器 0

 TSF0:
 串行状态寄存器 0 (CSIS0) 的第 0 位

**注:** 当数据写入缓冲 RAM 时,可能会产生一个等待状态。如需了解详细内容,可参见**第三十二章 等待注意事项**。

# (c) 重复发送模式

此模式用于重复发送存储在内部缓冲 RAM 中的数据。

当串行操作模式选择寄存器 0 (CSIMA0) 的第 7、6、5、3 位 (CSIAE0、ATE0、ATM0、TXEA0) 均为 1 时,设置串行触发寄存器 0 (CSIT0) 的第 0 位 (ATSTA0) =1,启动串行通信操作。

与自动发送模式不同,在发送完设置的字节个数后,不设置中断请求标志(ACSIIF),而是将自动数据传送地址计数寄存器 0(ADTC0)复位为 0,然后再次发送内部缓冲 RAM 中的内容。

如果不执行接收操作、忙控制和选通控制,则 SIA0/P143、BUSY0/BUZ/INTP7/P141 和 STB0/P145 可作为通用 I/O 端口引脚使用。

图 17-19 显示了重复发送模式的操作时序,图 17-20 显示了其操作流程图。

#### 图 17-19 重复发送模式操作时序



- 注意事项: 1. 由于在重复发送模式中,是在发送完 1 字节后从内部缓冲 RAM 中读取数据,因此在下一个发送之前插入一个间隔。对缓冲 RAM 的读操作与 CPU 操作同时进行时,间隔时间取决于自动数据传送间隔指定寄存器 0 (ADTIO)以及串行状态寄存器 0 (CSISO)的第 5 和 4 位 (STBEO, BUSYEO)的值(参见(5)自动发送/接收的间隔时间)。
- 2. 如果在间隔时间内,CPU 对缓冲 RAM 的访问与串行接口 CSIA0 对缓冲 RAM 的访问冲突,那么由自动数据传送间隔指定寄存器 0(ADTI0)指定的间隔时间可能会被延长。

图 17-20 重复发送模式流程图



CSIAE0: 串行操作模式选择寄存器 0 (CSIMAO)的第7位

 ADTP0:
 自动数据传送地址指针指定寄存器 0

 ADTI0:
 自动数据传送间隔指定寄存器 0

 ATSTA0:
 串行触发寄存器 0 (CSIT0) 的第 0 位

SIOA0: 串行 I/O 移位寄存器 0

ADTC0: 自动数据传送地址计数寄存器 0

注: 当数据写入缓冲 RAM 时,可能会产生一个等待状态。如需了解详细内容,可参见**第三十二章 等** 特注意事项。

# (d) 数据格式

在 SCKAO 下降沿同步修改数据,如下所示。

数据宽度恒为8位。通过设置CSIMA0的第1位(DIR0)可切换数据通信的方向。

# 图 17-21 CSIA0 发送/接收数据的格式

# (a) MSB-first (DIR0 位= 0)



# (b) LSB-first (DIR0 位 = 1)



# (e) 暂停自动发送/接收操作并重新启动

将串行触发寄存器 0 (CSIT0) 的第 1 位 (ATSTP0) 设置为 1,可以暂停自动发送/接收操作。在 8 位数据通信期间不能暂停发送/接收操作。可以在 8 位数据通信完成时暂停。 在暂停阶段,当第 8 位传送后,串行状态寄存器 0 (CSIS0)的第 0 位 (TSF0)被清零。

注意事项: 1. 如果在自动发送/接收期间执行 HALT 指令,则通信被暂停,并且,如果在 8 位数据通信期间设置 HALT 模式。在取消 HALT 模式后,从暂停点重新启动自动发送/接收操作。

2. 在暂停自动发送/接收操作并且 TSF0 = 1 时,不要将操作模式转变为 3 线串行 I/O 模式。

图 17-22 自动发送/接收操作的暂停和重新启动



ATSTP0: 串行触发寄存器 0 (CSIT0) 的第 1 位

ATSTA0: CSIT0 的第 0 位

#### (4) 同步控制

忙控制和选通控制用于同步主设备与从设备之间的发送/接收操作。 使用这些功能,可检测到发送位或接收位的移位操作。

# (a) 忙控制选项

当从设备输出到主设备的忙信号活动时,忙控制功能可以使处于串行发送/接收状态的主设备保持等待状态。

在使用忙控制选项时, 必须满足以下条件。

- 设置串行操作模式选择寄存器 0 (CSIMA0) 的第 6 位 (ATE0) =1。
- 设置串行状态寄存器 0 (CSISO) 的第 4 位 (BUSYEO) =1。

图 17-23 显示了使用忙控制选项时主设备与从设备的系统配置。

图 17-23 使用忙控制选项时的系统配置



主设备通过 BUSY0/BUZ/INTP7/P141 引脚接收从设备输出的忙信号,并在串行时钟下降沿同步采样输入的忙信号。即使在发送或接收 8 位数据时忙信号是活动的,主设备的发送/接收操作也无需等待。如果在完成该 8 位数据的发送/接收操作后的一个串行时钟的上升沿忙信号是活动的,则忙信号输入有效。此后,在忙信号活动期间,主设备的发送/接收操作保持等待状态。

由 CSIS0 的第 3 位(BUSYLV0)设置忙信号的活动电平。

BUSYLV0 = 1:高电平活动 BUSYLV0 = 0:低电平活动

当使用忙控制选项时,选择主设备模式。在从设备模式下不能实现忙控制。

图 17-24 为使用忙控制选项时的操作时序。

注意事项: 忙控制不能与自动数据传送间隔指定寄存器 0 (ADTI0)的间隔时间控制功能同时使用。



图 17-24 使用忙控制选项时(BUSYLV0=1)的操作时序

备注: ACSIIF: 中断请求标志

TSF0: 串行状态寄存器 0 (CSIS0) 的第 0 位

当忙信号不活动时,释放等待状态。如果采样到的忙信号不活动,则在下一个串行时钟的下降沿启动下一个8位数据的发送/接收操作。

由于忙信号与串行时钟是异步进行的,因此即使从设备将忙信号变为不活动,仍需要一个时钟的时间才采到忙信号。在采样忙信号后再经历 0.5 个时钟,才启动数据传送操作。

为了能够准确释放等待状态,从设备必须使忙信号的不活动状态保持到 SCKAO 下降。

图 17-25 为忙信号和释放等待状态的时序。图中显示了一个示例:一启动发送/接收操作,忙信号就变为活动状态。



图 17-25 忙信号与等待释放 (当 BUSYLV0 = 1)

#### (b) 忙控制与选通控制选项

选通控制用于同步主设备与从设备之间的发送/接收操作。当 8 位数据的发送/接收操作完成时,主设备从 STB0/P145 引脚输出选通信号。这样从设备可以确定结束数据发送操作的时序。因此,即使由于噪音在串 行时钟上的叠加而产生移位,也会建立同步,而下一个字节的发送不会受到移位的影响。 使用选通控制功能,必须满足以下条件:

- 设置串行操作模式选择寄存器 0 (CSIMA0) 的第 6 位 (ATE0) =1。
- 设置串行状态寄存器 0 (CSISO) 的第 5 位 (STBEO) =1。

通常,同时使用忙控制和选通控制选项作为握手信号。此时,从 STB0/P145 引脚输出选通信号,采样 BUSY0/BUZ/INTP7/P141 以保持当输入忙信号时的发送/接收等待状态。

将与第 9 个串行时钟的下降沿同步、从 STB0/P145 引脚持续输出一个传送时钟的高电平, 作为选通信号。在 8 位数据发送/接收操作完成后的两个串行时钟的上升沿检测忙信号。

图 17-26 显示了使用忙控制与选通控制选项时的操作时序。

当使用选通控制选项时,在输出选通信号后设置发送/接收操作完成中断请求标志(ACSIIF)。

图 17-26 使用忙控制与选通控制选项时的操作时序 (当 BUSYLV0 = 1)

注意事项: 当 TSF0 被清零时, SOA0 引脚变为低电平。

**备注:** ACSIIF: 中断请求标志

TSF0: 串行状态寄存器 0 (CSISO) 的第 0 位

#### (c) 根据忙信号进行位的移位检测

在自动发送/接收期间,由于噪声在主设备输出的串行时钟信号上的叠加,可能会出现从设备串行时钟的移位操作。此时如果不使用选通控制选项,移位操作会影响到下一个字节的发送。在这种情况下,主设备可使用忙控制选项,通过在发送期间检查忙信号,从而检测移位操作。

使用忙信号检测移位操作的过程如下:

在数据发送/接收期间,在第 8 个串行时钟上升沿之后,从设备输出忙信号(此时为避免由于忙信号而使发送/接收处于等待状态,应使忙信号在 2 个时钟内处于不活动状态)。

如果串行状态寄存器 0(CSIS0)的第 2 位(ERRE0)=1,则主设备采样忙信号与串行时钟的下降沿同步。如果没有产生移位,则在全部 8 个串行时钟的下降沿被采样的忙信号都是不活动的。如果在串行时钟下降沿被采样的忙信号是活动的,可以认定有移位产生,并执行错误处理过程(设置串行状态寄存器 0(CSIS0)的第 1 位(ERRF0)=1,暂停通信,并输出中断请求信号(INTACSI))。

尽管在完成 1 字节通信后通信操作被暂停,但是并不执行从设备信号输出、由于忙信号的等待以及由于 ADTIO 规定的间隔时间的等待操作。

如果 ERRE0 = 0,那么即使产生移位,ERRF0 也不能变为1。

图 17-27 显示了根据忙信号进行移位检测的操作时序。

#### 图 17-27 根据忙信号进行移位检测的操作时序 (当 BUSYLV0 = 1)



ACSIIF: 中断请求标志

CSIAE0: 串行操作模式选择寄存器 0 (CSIMA0) 的第7位

ERRF0: 串行状态寄存器 0 (CSISO) 的第 1 位

#### (5) 自动发送/接收间隔时间

当使用自动发送/接收功能时,在发送/接收完一个字节后,执行对内部缓冲 RAM 的读/写操作。因此在执行下一个发送/接收操作之前插入一个间隔时间。

在通过内部时钟使用自动发送/接收功能时,由于对缓冲 RAM 的读/写操作与 CPU 操作并行进行,因此间隔时间取决于自动数据传送间隔指定寄存器 0(ADTIO)以及串行状态寄存器 0(CSISO)的第 5 和 4 位(STBEO,BUSYEO)的值。 当 ADTIO 被清零(00H)时,会产生一个基于 STBEO 和 BUSYEO 设置的间隔时间。

当 ADTI0 被清零(00H),插入一个基于 STBE0 和 BUSYE0 设置的间隔时间。例如,当 ADTI0 = 00H 且 STBE0 = BUSYE0 = 1 时,则插入 2 个时钟的间隔时间,并且可以通过使用外部忙信号进一步延长间隔时间。如果 ADTI0 设置的间隔时间至少为 2 个时钟,则无论 STBE0 和 BUSYE0 设置如何,都将产生由 ADTI0 设置的间隔时间。当 BUSYE0 = 1 时,可以通过使用外部忙信号进一步延长间隔时间。

举例: 当 ADTIO = 00H 时且未产生忙信号时的间隔时间

 <1>当 STBE0 = 1, BUSYE0 = 0:
 产生两个串行时钟的间隔时间

 <2>当 STBE0 = 0, BUSYE0 = 1:
 产生一个串行时钟的间隔时间

 <3>当 STBE0 = 1, BUSYE0 = 1:
 产生两个串行时钟的间隔时间

图 17-28 自动发送/接收间隔时间举例 (当 ADTI0 = 00H, STBE0 = 1, BUSYE0 = 0 (两个时钟))



ACSIIF: 中断请求标志

# 第十八章 串行接口 IIC0

# 18.1 串行接口 IIC0 的功能

串行接口 IICO 有以下两种模式。

#### (1) 操作停止模式

在不进行串行传送时可采用此模式, 以降低功耗。

# (2) I<sup>2</sup>C 总线模式 (支持多个主设备)

该模式采用两条线(一条串行时钟(SCL0)总线和一条串行数据总线(SDA0))进行多设备的 8 位数据传送。 该模式遵循 I<sup>2</sup>C 总线格式并且主设备能够通过串行数据总线,产生"起始条件","地址","传送方向指示","数据" 和"停止条件"等信号传送至从设备。从设备能够通过硬件自动地检测这些接收到的状态和数据。这个功能可以简化控制 I<sup>2</sup>C 总线的应用程序部分。

由于 SCL0 和 SDA0 引脚是开漏输出,IICO 总线的串行时钟线和串行数据总线需要连接上拉电阻。

图 18-1 是串行接口 IIC0 的框图。

\*

图 18-1 串行接口 IIC0 框图



图 18-2 是串行总线配置示例。

图 18-2 使用 I<sup>2</sup>C 总线的串行总线配置示例



#### 18.2 串行接口 IIC0 的配置

串行接口 IICO 包括下列硬件。

表 18-1 串行接口 IIC0 配置

| 项目    | 配置                                                                                                                             |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 寄存器   | IIC 移位寄存器 0(IIC0)<br>从设备地址寄存器 0(SVA0)                                                                                          |
| 控制寄存器 | IIC 控制寄存器 0(IICC0) IIC 状态寄存器 0(IICS0) IIC 标志寄存器 0(IICF0) IIC 时钟选择寄存器 0(IICCL0) IIC 功能扩展寄存器 0(IICX0) 端口模式寄存器 6(PM6) 端口寄存器 6(P6) |

# (1) IIC 移位寄存器 0(IIC0)

IIC0 用于 8 位串行数据和 8 位并行数据的相互转换,并且和串行时钟同步。IIC0 可以用来发送和接收数据。对 IIC0 的读写操作可以控制实际的发送和接收操作。

在等待期间通过对 IICO 写入数据,可以取消等待状态并起始数据传送操作。

可由 8 位存储器操作指令设置 IICO。

复位信号将 IICO 清零。

#### 图 18-3 IIC 转换寄存器 0 的格式 (IIC0)

| 地址:  | FFA5H | 复位后: | 00H R/V | V |   |   |   |   |
|------|-------|------|---------|---|---|---|---|---|
| 符号   | 7     | 6    | 5       | 4 | 3 | 2 | 1 | 0 |
| IIC0 |       |      |         |   |   |   |   |   |

注意事项: 1. 在数据传送期间不要对 IIC0 进行写操作。

2. 仅在等待期间才能对 IIC0 进行读写操作。除等待期间外,禁止在其他的通信状态下访问 IIC0。然 而,作为主设备时,在通信触发位(STT0)被设为 1 之后 IIC0 只能被写入一次。

# (2) 从设备地址寄存器 0(SVA0)

该寄存器用于在从设备模式下存储本地地址。

可由 8 位存储器操作指令设置 SVA0。

但是当 STD0=1 时,禁止重写该寄存器(当检测到起始条件时)。

复位信号将 SVA0 清零。

图 18-4 从地址寄存器 0 的格式 (SVA0)



注: 第0位恒为0。

#### (3) SO 锁存器

SO 锁存器用来保持 SDA0 引脚的输出电平。

#### (4) 唤醒控制器

当该寄存器接收的地址与从设备地址寄存器 0(SVA0)设置的地址匹配,或者当接收到一个扩展代码时,这个电路将产生一个中断请求信号(INTIICO)。

#### (5) 预分频器

用于选择采样时钟。

#### (6) 串行时钟计数器

该计数器对发送/接收操作期间输出或输入的串行时钟进行计数,同时用于验证8位数据是否已发送或接收。

## (7) 中断请求信号发生器

此电路用于控制中断请求信号(INTIICO)的产生。

- 一个  $I^2$ C 中断请求由下列两个触发条件产生:
- 串行时钟的第8或第9个下降沿(通过 WTIM0 位设置)
- 当检测到停止条件(通过 SPIE0 位设置)时

**备注:** WTIM0 位: IIC 控制寄存器 0 (IICC0)的第 3 位 SPIE0 位: IIC 控制寄存器 0 (IICC0)的第 4 位

#### (8) 串行时钟控制器

在主设备模式下,此电路通过 SCL0 引脚,从采样时钟产生时钟输出。

#### (9) 串行时钟等待控制器

用于控制等待时序。

# (10) ACK 信号发生器,停止条件检测器,起始条件检测器和 ACK 信号检测器

这些电路用于产生和检测每种状态。

#### (11) 数据保持时间修正电路

此电路根据串行时钟的下降沿产生数据保持时间。

#### (12) 起始条件发生器

当 STT0 位为 1 时,该电路产生一个起始条件信号。

但是,在禁止通信预约的状态下(IICRSV 位 = 1),只要总线尚未被释放(IICBSY 位 = 1),起始条件请求将被忽略并且 STCF 被置为 1。

# ★ (13) 停止条件发生器

当 SPT0 位为 1 时,此电路产生一个停止条件信号。

## (14) 总线状态检测器

此电路通过检测起始条件和停止条件来确定总线是否被释放。 然而,如果操作后总线状态无法被立即检测到,则初始状态由 STCEN 位来设置。

**备注:** STT0 位: IIC 控制寄存器 0 (IICC0)的第 1 位

SPT0 位: IIC 控制寄存器 0 (IICC0)的第 0 位

 IICRSV 位:
 IIC 标志寄存器 0 的第 0 位

 IICBSY 位:
 IIC 标志寄存器 0 的第 6 位

 STCF 位:
 IIC 标志寄存器 0 的第 7 位

 STCEN 位:
 IIC 标志寄存器 0 的第 1 位

## 18.3 控制串行接口 IIC0 的寄存器

串行接口 IIC0 由下列 7 个寄存器控制:

- IIC 控制寄存器 O(IICCO)
- IIC 标志寄存器 0 (IICF0)
- IIC 状态寄存器 0 (IICS0)
- IIC 时钟选择寄存器 0 (IICCL0)
- IIC 功能扩展寄存器 0 (IICX0)
- 端口模式寄存器 6 (PM6)
- 端口寄存器 6 (P6)

## (1) IIC 控制寄存器 0 (IICC0)

这个寄存器用于允许/停止  $I^2C$  的操作、设置等待时间和设置  $I^2C$  的其他操作。

可由 1 位或 8 位存储器操作指令对 IICC0 进行设置。但必须在 IICE0 = 0 或者在等待期间设置 SPIE0,WTIM0,和 ACKE0 位。当 IICE0 位从"0"变为"1"时,这些位可以同时被设置。

复位信号将 IICCO 清零。

## 图 18-5. IIC 控制寄存器 0 (IICC0)的格式 (1/4)

地址: FFA6H 复位后: 00H R/W 符号 <7> <6> <5> <4> <3> <2> <1> <0> IICC0 IICE0 WREL0 SPIE0 WTIM0 ACKE0 SPT0 LREL0 STT0

| IICE0                               | I <sup>2</sup> C 操作允许                             |          |
|-------------------------------------|---------------------------------------------------|----------|
| 0                                   | 停止操作。复位 IIC 状态寄存器 0(IICS0) <sup>±1</sup> 。停止内部操作。 |          |
| 1                                   | 允许操作                                              |          |
| 当 SCL0 和 S                          | 当 SCL0 和 SDA0 在高电平时,必须将该位设置为 1。                   |          |
| 清零条件 (IIC                           | IICE0 = 0) 设置条件 (IICE0 = 1)                       |          |
| <ul><li>通过指令清零</li><li>复位</li></ul> |                                                   | • 通过指令设置 |

| LREL0 <sup>262</sup>               | 退出通信                                                                                                                                                                                                      |                  |
|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0                                  | 正常操作                                                                                                                                                                                                      |                  |
| 1                                  | 此时从当前的通信模式退出,进入待机模式。当执行此操作后设置的值自动清零。<br>用于那些已接受了本地无关扩展码的情况。<br>SCL0 和 SDA0 线被设置为高阻抗状态。<br>下列 IIC 控制器 0 (IICC0) 和 IIC 状态寄存器 0 (IICS0)的标志位被清零。<br>• STT0 • SPT0 • MSTS0 • EXC0 • COI0 • TRC0 • ACKD0 • STD0 |                  |
| • 检测到停止                            | 从通信模式退出后一直保持待机模式,直到满足下列通信条件。  • 检测到停止条件后,在主设备模式下重新启动。  • 启动后,发生地址匹配或接收到扩展码。                                                                                                                               |                  |
| 清零条件 (LREL0 = 0) 设置条件 (LREL0 = 1)  |                                                                                                                                                                                                           | 设置条件 (LREL0 = 1) |
| <ul><li>执行后自动</li><li>复位</li></ul> | 清零                                                                                                                                                                                                        | • 通过指令设置         |

| WREL0 *2                           |                                                                                  | 等待取消             |
|------------------------------------|----------------------------------------------------------------------------------|------------------|
| 0                                  | 不取消等待                                                                            |                  |
| 1                                  | 取消等待。在等待取消后,此设置被自动清除。                                                            |                  |
|                                    | 在第 9 个时钟脉冲的下降沿有效启动的发送状态(TRC0 = 1)下,在等待期间设置 WREL0(等待取消)时,SDA0 将进入高阻抗状态(TRC0 = 0)。 |                  |
| 清零条件 (V                            | VREL0 = 0)                                                                       | 设置条件 (WREL0 = 1) |
| <ul><li>执行后自动</li><li>复位</li></ul> | 清零                                                                               | • 通过指令设置         |

- **注:** 对 IICS0 寄存器、IICF0 寄存器的 STCF0 位与 IICBSY 位和 IICCL0 寄存器的 CLD0 位与 DAD0 位进行 复位。
  - 2. 当 IICE0 = 0 时,本标志信号无效。
- ★ 注意事项: 允许 I<sup>2</sup>C 操作(IICE0 = 1)后,在 SCL0 为高电平并且 SDA0 为低电平时,立即检测到起始条件。允许 I<sup>2</sup>C 操作(IICE0 = 1)后,立即通过 1 位存储器操作指令设置 LREL0(1)。

# 图 18-5 IIC 控制寄存器 0 (IICC0)的格式 (2/4)

| SPIE0 <sup>±1</sup>                 | 当检测到停止条件时,允许/禁止产生中断请求 |                  |
|-------------------------------------|-----------------------|------------------|
| 0                                   | 禁止                    |                  |
| 1                                   | 允许                    |                  |
| 清零条件 (SF                            | PIE0 = 0)             | 设置条件 (SPIE0 = 1) |
| <ul><li>通过指令清零</li><li>复位</li></ul> |                       | • 通过指令进行设置       |

| WTIM0 <sup>≇1</sup>                 | 对等待和中断请求产生的控制                                                                                                                                                                 |                  |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0                                   | 在第8个时钟的下降沿产生中断请求。<br>主设备模式:输出8个时钟之后,将时钟输出设置为低电平且设置等待状态。<br>从设备模式:输入8个时钟之后,将时钟设置为低电平且为主设备设置等待状态。                                                                               |                  |
| 1                                   | 在第9个时钟的下降沿产生中断请求。<br>主设备模式:输出9个时钟之后,将时钟输出设置为低电平且设置等待状态。<br>从设备模式:输入9个时钟之后,将时钟设置为低电平且设置主设备等待状态。                                                                                |                  |
| 在地址传送期                              | 地址传送期间,在第 9 个时钟的下降沿产生中断,而与该位的设置无关。地址传送完成之后该位设置才有效。主设备模式下,在地址传送期间的第 9 个时钟的下降沿插入一个等待信号。对于已接收到本地地址的从设备,在发出应答信号(ACK)之后的第 9 个时钟的下降沿插入一个等待信号。但是,当从设备已经收到一个扩展码时,将在第 8 个时钟的下降沿插入等待信号。 |                  |
| 清零条件 (WTIM0 = 0)                    |                                                                                                                                                                               | 设置条件 (WTIM0 = 1) |
| <ul><li>通过指令清零</li><li>复位</li></ul> |                                                                                                                                                                               | • 通过指令进行设置       |

| ACKE0 <sup>± 1,2</sup>                | 应答控制                                                |            |
|---------------------------------------|-----------------------------------------------------|------------|
| 0                                     | 禁止应答                                                |            |
| 1                                     | 允许应答。在第9个时钟期间,将SDA0设置为低电平。但是,在非扩展模式及地址传送期间,ACK信号无效。 |            |
| 清零条件 (AC                              | 序条件 (ACKE0 = 0) 设置条件 (ACKE0 = 1)                    |            |
| <ul><li>通过指令进行清零</li><li>复位</li></ul> |                                                     | • 通过指令进行设置 |

**注:** 1. IICE0 = 0 时,此标志信号无效。

**2.** 在地址传送期间及编码为非扩展码时,所设的值无效。 在从设备模式下并且地址匹配时,无论设置何值都将产生应答信号。

## 图 18-5 IIC 控制寄存器 0 (IICC0) 的格式 (3/4)

| STT0 * | 起始条件触发                                                                                                                                                                                                                                                    |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0      | 不产生起始条件                                                                                                                                                                                                                                                   |  |
| 1      | 总线释放时(STOP 模式下): 产生一个起始条件(作为主设备启动)。SCL0 处于高电平时,SDA0 从高电平变为低电平时产生起始条件。然后,经过额定时间,SCL0 变为低电平。 有第三方通信时: • 当允许通信预约时(IICRSV = 0)。该位作为起始条件预约标志。设置为 1 时,在总线释放之后自动产生一个起始条件。 • 当禁止通信预约时(IICRSV = 1) 将 STCF 设置为 1,且 STT0 被清零。不产生起始条件。 等待状态(主设备模式): 退出等待状态之后产生一个重启条件。 |  |
|        | 设置时序的注意事项                                                                                                                                                                                                                                                 |  |

- ▶ 主设备接收: 传送期间不能设置为 1。仅在 ACKE0 被清零且从设备通报结束接收时的等待期间,才能设为 1。
- 主设备发送: 应答期间内,不能正常产生起始条件。在第9个时钟输出后的等待期间可以设置为1。
- 不能和 SPT0 同时设为 1。
- 禁止在 STT0 被清零前重复设置为 1。

| ▼ 赤正任 0110 数日 ₹ 的 主交 攻 巨 // 1。         |                 |
|----------------------------------------|-----------------|
| 清零条件 (STT0 = 0)                        | 设置条件 (STT0 = 1) |
| • 禁止通信预约时,通过将 SST0 设置为 1 进行清零 由仲裁失败清零  | • 通过指令进行设置      |
| 通过主设备产生起始条件后进行清零     由 LREL0=1(退出通信)清零 |                 |
| • 当 IICE0 = 0 (操作停止)时                  |                 |
| <ul><li>● 复位</li></ul>                 |                 |

注: IICE0 = 0 时,该标志信号无效。

# **备注:** 1. 第 1 位 (STT0)在设置后再读取时将会变为 0。

2. IICRSV: IIC 标志寄存器 (IICF0)的第 0 位 STCF: IIC 标志寄存器 (IICF0)的第 7 位

\*

## 图 18-5 IIC 控制寄存器 0 (IICC0)的格式 (4/4)

| SPT0 | 停止条件触发器                                                                                    |
|------|--------------------------------------------------------------------------------------------|
| 0    | 不产生停止条件                                                                                    |
| 1    | 产生停止条件 (结束主设备传送)<br>SDAO 变为低电平后,设置 SCLO 为高电平或等待其变为高电平。然后,经过额定时间后,SDAO 从低电平变为高电平,则产生一个停止条件。 |

#### 设置时序注意事项

• 主设备接收: 传送期间不能设为1。

仅在 ACKE0 被清零且从设备通报结束接收时的等待期间,才能设为 1。

• 主设备发送: 应答期间内,不能正常产生停止条件。在第9个时钟输出后的等待期间可以设为1。

- 不能和 SST0 同时设置为 1
- 仅在主设备模式<sup>推</sup>下, SPT0 才能设置为 1
- WTIMO 清零后,如果在输出 8 个时钟之后的等待期间将 SPTO 设为 1,那么注意,在第 9 个时钟的高电平期间将产生一个停止条件。在输出 8 个时钟后的等待期间 WTIMO 应从 0 变为 1,并且在输出第 9 个时钟后的等待期间 SPTO 应被设置为 1。
- ●禁止在 SPT0 被清零前重复设置为 1。

| 清零条件 (SPT0 = 0)       | 设置条件 (SPT0 = 1) |
|-----------------------|-----------------|
| • 由仲裁失败清零             | • 通过指令进行设置      |
| • 检测到停止条件后自动清零        |                 |
| ● 可由 LREL0=1(退出通信)清零  |                 |
| ● IICE0 = 0 时(操作停止)   |                 |
| <ul><li>●复位</li></ul> |                 |

**注:** 仅在主设备模式下 SPT0 可设置为 1。但是,在切换到允许操作状态后检测到第 1 个停止条件之前必须将 SPT0 设置为 1,产生停止条件。如需了解详细信息,可参见 18.5.15 其他注意事项。

注意事项: 在第 9 个时钟, 当 IIC 状态寄存器 0(IICS0)的第 3 位(TRC0)被设为 1 和 WREL0 设置为 1 时, , 取消等待状态后, TRC0 被清零, SDA0 线被设为高阻抗状态。

**备注:** 第 0 位 (SPT0)在设置后再读取时将变为 0。

## (2) IIC 状态寄存器 0 (IICS0)

此寄存器用于表示  $I^2C$  的状态。

仅当 STT0 = 1 且在等待期间,才能通过 1 位或 8 位存储器操作指令读取 IICS0。

复位信号的产生将 IICSO 设置为 00H。

注意事项: 如果从 IICS0 中读取数据,将产生一个等待周期。当 CPU 使用子系统时钟且外围硬件时钟停止时,不要从 IICS0 中读取数据。详见第三十二章 等待注意事项。

# 图 18-6 IIC 状态寄存器 0 (IICS0) 的格式 (1/3)

地址: FFAAH 复位后: 00H R 符号 <7> <6> <5> <4> <3> <2> <1> <0> IICS0 CO<sub>10</sub> TRC0 ACKD0 STD0 SPD0 MSTS0 ALD0 EXC0

| MSTS0                                                                                                                        |              | 主设备状态            |
|------------------------------------------------------------------------------------------------------------------------------|--------------|------------------|
| 0                                                                                                                            | 从设备状态或通信待机状态 |                  |
| 1                                                                                                                            | 主设备通信状态      |                  |
| 清零条件 (MSTS0 = 0)                                                                                                             |              | 设置条件 (MSTS0 = 1) |
| <ul> <li>检测到停止条件时</li> <li>ALD0=1 时(仲裁失败)</li> <li>由 LREL0=1 (退出通信)清零</li> <li>IICE0 从 1 变为 0 (操作停止)时</li> <li>复位</li> </ul> |              | • 起始条件产生时        |

| ALD0                                                                                             | 仲裁失败的检测                    |              |
|--------------------------------------------------------------------------------------------------|----------------------------|--------------|
| 0                                                                                                | 此状态表示没有仲裁或仲裁结果为"获胜"。       |              |
| 1                                                                                                | 此状态表示仲裁结果为"失败"。MSTSO 被清零。  |              |
| 清零条件 (                                                                                           | (ALD0 = 0) 设置条件 (ALD0 = 1) |              |
| <ul> <li>•读取<sup>推</sup> IICS0 之后自动清零</li> <li>• IICE0 从 1 变为 0 (操作停止)时</li> <li>• 复位</li> </ul> |                            | ●仲裁结果为"失败"时。 |

| EXC0                                                                                                                     | 扩展码接收的检测 |                                                  |
|--------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------|
| 0                                                                                                                        | 未接收到扩展码  |                                                  |
| 1                                                                                                                        | 接收到扩展码   |                                                  |
| 清零条件 (EXC0 = 0)                                                                                                          |          | 设置条件 (EXC0 = 1)                                  |
| <ul> <li>检测到起始条件时</li> <li>检测到停止条件时</li> <li>由 LREL0 = 1 (退出通信)清零</li> <li>IICE0 从 1 变为 0 (操作停止)时</li> <li>复位</li> </ul> |          | ● 当接收到的地址数据的高 4 位为"0000"或"1111"时(在第 8 个时钟的上升沿设置) |

**注:** 即使使用 1 位存储器操作指令没有对 IICSO 进行操作,此寄存器也会清零。因此当使用 ALDO 位时,应 先读取该位数据。

**备注:** LREL0: IIC 控制寄存器 0(IICC0)的第 6 位 IICE0: IIC 控制寄存器 0(IICC0)的第 7 位

# 图 18-6 IIC 状态寄存器 0 (IICS0) 的格式 (2/3)

| COI0  | 地址匹配的检测   |                                                         |
|-------|-----------|---------------------------------------------------------|
| 0     | 地址不匹配     |                                                         |
| 1     | 地址匹配      |                                                         |
| 清零条件( | COI0 = 0) | 设置条件 (COI0 = 1)                                         |
|       |           | • 当接收地址和本地地址(从设备地址寄存器 0 (SVA0)的内容)匹配时<br>(在第8个时钟的上升沿设置) |

| TRC0                                                                                                           | 发送/接收状态的检测                                                                                                                                                     |                                                                                          |
|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| 0                                                                                                              | 接收状态(非发送状态)。 SDA0 线被设为高阻抗状态。                                                                                                                                   |                                                                                          |
| 1                                                                                                              | 发送状态。允许将 SOO 锁存器中的内容输出到 SDAO 线 (在第 1 个字节的第 9 个时钟的下降沿才有效)。                                                                                                      |                                                                                          |
| 清零条件(                                                                                                          | TRC0 = 0)                                                                                                                                                      | 设置条件 (TRC0 = 1)                                                                          |
| • 检测到停。<br>• 由 LRELC<br>• IICEO 从<br>• 由 WREL<br>• ALDO 从 (<br>• 复位<br><主设备模。<br>• 当"1"输出<br><从设备模。<br>• 检测到起。 | 0 = 1(退出通信)清零<br>1 变为 0 (操作停止)时<br>0 = 1 <sup>tt</sup> (取消等待)清零<br>0 变为 1 (仲裁失败)时<br>式><br>到第 1 个字节的 LSB (传送方向指示位)时<br>式><br>始条件时<br>入到第 1 个字节的 LSB (传送方向指示位)时 | <主设备模式> •产生起始条件时 •当"0"输出到第 1 个字节的 LSB (传送方向指示位)时 <从设备模式> •当"1"输入到第 1 个字节的 LSB (传送方向指示位)时 |

**注:** 当 IIC 状态寄存器 0(IICS0)的第 3 位(TRC0)为 1 时,通过在第 9 个时钟将 IIC 控制寄存器 0(IICC0)的第 5 位(WREL0)设置为 1,来取消等待状态,TRC0 被清零且 SDA0 线进入高阻抗状态。

**备注:** LRELO: IIC 控制寄存器 0 (IICCO)的第 6 位 IICEO: IIC 控制寄存器 0 (IICCO)的第 7 位

## 图 18-6 IIC 状态寄存器 0 (IICS0)的格式(3/3)

| ACKD0                                                                                       | 应答信号的检测 (ACK)                    |                                      |
|---------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------|
| 0                                                                                           | 未检测到应答信号                         |                                      |
| 1                                                                                           | 已检测到应答信号                         |                                      |
| 清零条件 (A                                                                                     | 影条件 (ACKD0 = 0) 设置条件 (ACKD0 = 1) |                                      |
| ●检测到停止条件时<br>●在下一个字节的第一个时钟的上升沿<br>●由 LREL0 = 1 (退出通信)清零<br>●当 IICE0 从 1 变为 0 (操作停止)时<br>●复位 |                                  | • 在 SCL0 的第 9 个时钟的上升沿将 SDA0 线设为低电平之后 |

| STD0                                                                                                 | 起始条件的检测                       |                             |
|------------------------------------------------------------------------------------------------------|-------------------------------|-----------------------------|
| 0                                                                                                    | 未检测到起始条件                      |                             |
| 1                                                                                                    | 已检测到起始条件。这表示地址传送阶段有效。         |                             |
| 清零条件(                                                                                                | 条件 (STD0 = 0) 设置条件 (STD0 = 1) |                             |
| ●检测到停止条件时<br>●在地址发送之后的下一个字节的第 1 个时钟的上升沿<br>●由 LREL0 = 1 (退出通信)清零<br>●当 IICE0 从 1 变为 0 (操作停止)时<br>●复位 |                               | <ul><li>◆检测到起始条件时</li></ul> |

| SPD0                                                                                            | 停止条件的检测                |                             |
|-------------------------------------------------------------------------------------------------|------------------------|-----------------------------|
| 0                                                                                               | 未检测到停止条件               |                             |
| 1                                                                                               | 已检测到停止条件。主设备通信结束,释放总线。 |                             |
| 清零条件 (SPD0 = 0)                                                                                 |                        | 设置条件 (SPD0 = 1)             |
| <ul><li>• 在设置该位并检测到起始条件后的地址发送字节第1个时钟的上升沿</li><li>• 当 IICE0 从1变为0 (操作停止)时</li><li>• 复位</li></ul> |                        | <ul><li>◆检测到停止条件时</li></ul> |

**备注:** LRELO: IIC 控制寄存器 0(IICCO)的第 6 位 IICEO: IIC 控制寄存器 0(IICCO)的第 7 位

# (3) IIC 标志寄存器 0 (IICF0)

此寄存器用于设置  $I^2C$  的操作模式,并指示  $I^2C$  总线的状态。

IICF0可由 1 位或 8 位的存储器操作指令进行设置。但是,STCF 和 IICBSY 位是只读的。

IICRSV 位用于允许/禁止通信预约功能 (详见 18.5.14 通信预约)。

STCEN 用于设置 IICBSY 的初始值 (详见 18.5.15 其他注意事项)。

仅当  $I^2$ C 操作被禁止(IIC 控制寄存器 0 (IICC0)的第 7 位(IICE0) = 0)时才可对 IICRSV 和 STCEN 位进行写操作。 当允许操作时,可以读取 IICF0 寄存器。

复位信号的产生将 IICF0 变为 00H。

## 图 18-7 IIC 标志寄存器 0 (IICF0)的格式

 地址: FFABH
 复位后: 00H
 R/W<sup>ith</sup>

 符号 <7> <6> 5
 4
 3
 2
 <1> <0>

 IICF0
 STCF
 IICBSY
 0
 0
 0
 STCEN
 IICRSV

| STCF                                                               | ST                | TO 清零标志                             |
|--------------------------------------------------------------------|-------------------|-------------------------------------|
| 0                                                                  | 产生起始启动条件          |                                     |
| 1                                                                  | 未能产生起始条件: STT0 清零 |                                     |
| 清零条件 (STCF=0)                                                      |                   | 设置条件 (STCF=1)                       |
| <ul><li>通过 STT0=1 清零</li><li>IICE0=0 时 (操作停止)</li><li>复位</li></ul> |                   | 当禁止通信预约时(IICRSV=1),未能产生起始条件且STT0被清零 |

| IICBSY                                                        | I <sup>2</sup> C 总线状态标志         |                                    |
|---------------------------------------------------------------|---------------------------------|------------------------------------|
| 0                                                             | 总线释放状态 (当 STCEN0=1 时的通信初始状态)    |                                    |
| 1                                                             | 总线通信状态 (当 STCEN0=0 时的通信初始状态)    |                                    |
| 清零条件                                                          | 清零条件 (IICBSY=0) 设置条件 (IICBSY=1) |                                    |
| <ul><li>检测到停止条件</li><li>IICE0=0 时 (操作停止)</li><li>复位</li></ul> |                                 | ● 检测到起始条件<br>● 当 STCEN=0 时设置 IICE0 |

| STCEN                                  | 允许初始启动触发                                 |                |
|----------------------------------------|------------------------------------------|----------------|
| 0                                      | 允许操作后 (IICE0=1),可以在检测到停止条件的基础上产生一个起始条件。  |                |
| 1                                      | 允许操作后 (IICE0=1),可以在不检测到停止条件的基础上产生一个起始条件。 |                |
| 清零条件 (STCEN=0) 设置条件 (STCEN=1)          |                                          | 设置条件 (STCEN=1) |
| <ul><li> 检测到停止条件</li><li> 复位</li></ul> |                                          | ● 通过指令进行设置     |

| IICRSV          | 通信预约功能禁止位 |                 |
|-----------------|-----------|-----------------|
| 0               | 允许通信预约    |                 |
| 1               | 禁止通信预约    |                 |
| 清零条件 (IICRSV=0) |           | 设置条件 (IICRSV=1) |
| 通过指令进行清零     复位 |           | ● 通过指令进行设置      |

注: 第6位和第7位是只读的。

注意事项: 1. 仅当操作停止(IICE0 = 0)时才可对 STCEN 进行写操作。

- 2. 当 STCEN = 1 时不论总线处于何种状态,总线释放状态(IICBSY = 0)都可以识别,因此当第 一个起始条件产生(STT0 = 1)时,必须确保没有第三方通信,以防通信被破坏。
- 3. 仅当操作停止(IICE0 = 0)时才可对 IICRSV 进行写操作。

**备注:** STT0: IIC 控制寄存器 0 (IICC0)的第 1 位 IICE0: IIC 控制寄存器 0 (IICC0)的第 7 位

## (4) IIC 时钟选择寄存器 0 (IICCL0)

此寄存器用来为 I<sup>2</sup>C 总线设置传送时钟。

可由 1 位或 8 位的存储器操作指令设置 IICCL0。但是,CLD0 和 DAD0 位是只读的。应根据 IIC 功能扩展寄存器 0 (IICX0)的第 0 位(CLX0)设置 SMC0、CL01 和 CL00 位(详见 **18.3 (6) 1 2 C 传送时钟设置方法**)。

★ IIC 控制寄存器 0 (IICC0)的第7位(IICE0)为 0 时设置 IICCL0。

复位信号的产生将 IICCL0 设置为 00H。

# 图 18-8 IIC 时钟选择寄存器 0 (IICCL0)的格式

复位后: 00H R/W <sup>推</sup> 地址: FFA8H 符号 6 <4> <3> <2> 1 0 IICCL0 SMC0 0 0 CLD0 DAD0 DFC0 CL01 CL00

| CLD0                                                                | SCL0 引脚电平的检测(仅当 IICE0 = 1 时有效) |                 |
|---------------------------------------------------------------------|--------------------------------|-----------------|
| 0                                                                   | SCL0 引脚在低电平被检测。                |                 |
| 1                                                                   | SCL0 引脚在高电平被检测。                |                 |
| 清零条件 (CLD0 = 0)                                                     |                                | 设置条件 (CLD0 = 1) |
| <ul><li>SCL0 引脚为低电平时</li><li>IICE0 = 0 (操作条件)时</li><li>复位</li></ul> |                                | • SCLO 引脚为高电平时  |

| DAD0                                                                | SDA0 引脚电平的检测(仅当 IICE0 = 1 时有效) |                 |
|---------------------------------------------------------------------|--------------------------------|-----------------|
| 0                                                                   | SDA0 引脚在低电平被检测                 |                 |
| 1                                                                   | SDA0 引脚在高电平被检测                 |                 |
| 清零条件 (DAD0 = 0)                                                     |                                | 设置条件 (DAD0 = 1) |
| <ul><li>SDA0 引脚为低电平时</li><li>IICE0 = 0 (操作条件)时</li><li>复位</li></ul> |                                | • SDA0 引脚为高电平时  |

| SM | <b>ЛС</b> 0 | 操作模式切换 |
|----|-------------|--------|
|    | 0           | 标准模式   |
|    | 1           | 高速模式   |

| DFC0 | 数字滤波器操作控制                                                      |  |  |  |  |
|------|----------------------------------------------------------------|--|--|--|--|
| 0    | 关闭数字滤波器                                                        |  |  |  |  |
| 1    | 打开数字滤波器                                                        |  |  |  |  |
| >>   | 数字滤波器只能用于高速模式<br>在高速模式下,不论 DFC0 位如何设置(设置(1)/清除(0)),传送时钟不会发生变化。 |  |  |  |  |

注: 第4位和第5位是只读的。

数字滤波器用于高速模式下的噪声消除

**备注:** IICE0: IIC 控制寄存器 0 (IICC0)的第7位

## (5) IIC 功能扩展寄存器 0 (IICX0)

此寄存器用于设置 I<sup>2</sup>C 的功能扩展。

可由 1 位或 8 位存储器操作指令设置 IICXO。根据 IIC 时钟选择寄存器 0(IICCL0)的第 3、1 和 0 位(SMC0、CL01 和 CL00)设置 CLX0 (详见 **18.3 (6)** I<sup>2</sup>C 传送时钟设置方法)。

IIC 控制寄存器 0(IICC0)的第7位(IICE0)为0时设置 IICX0。

复位信号将 IICX0 清零。

# 图 18-9 IIC 功能扩展寄存器 0(IICX0)的格式

| 地址: FFA | 9H | 复位后: 00H | H R/W | 1 |   |   |   |      |
|---------|----|----------|-------|---|---|---|---|------|
| 符号      | 7  | 6        | 5     | 4 | 3 | 2 | 1 | <0>  |
| IICX0   | 0  | 0        | 0     | 0 | 0 | 0 | 0 | CLX0 |

# (6) I<sup>2</sup>C 传送时钟设置方法

 $I^2C$  传送时钟的频率 (fscL)通过下列表达式计算。

$$fscl = 1/(m \times T + t_R + t_F)$$

m = 12、18、24、44、66、86 (详见表 18-2 选择时钟设置)

T: 1/fw

tr: SCL0 上升时间 tr: SCL0 下降时间

- $\star$  fscL = 1/(88 × 238.7 ns + 200 ns + 50 ns)  $\cong$  48.1 kHz



通过 IIC 时钟选择寄存器 0(IICCL0)的第 3、1 和 0 位 (SMC0、CL01 和和 CL00)与 IIC 功能扩展寄存器 0(IICX0)的 第 0 位(CLX0)设置选择时钟。

 $\star$ 

表 18-2 选择时钟设置

| IICX0 |      | IICCL0 |      | 选择时钟    | 传送时钟   | 可设置的选择时钟(fw)范围                  | 操作模式       |
|-------|------|--------|------|---------|--------|---------------------------------|------------|
| 第0    | 第3   | 第1     | 第 0  | (fw)    | (fw/m) |                                 |            |
| 位     | 位    | 位      | 位    |         |        |                                 |            |
| CLX0  | SMC0 | CL01   | CL00 |         |        |                                 |            |
| 0     | 0    | 0      | 0    | fprs/2  | fw/44  | $2.00\sim$ 4.19 MHz             | 正常模式       |
| 0     | 0    | 0      | 1    | fprs/2  | fw/86  | $4.19 \sim 8.38~\mathrm{MHz}$   | (SMC0 = 0) |
| 0     | 0    | 1      | 0    | fprs/4  | fw/86  |                                 |            |
| 0     | 0    | 1      | 1    | fexscl0 | fw/66  | 6.4 MHz                         |            |
| 0     | 1    | 0      | ×    | fprs/2  | fw/24  | $4.00 \sim$ $8.38~\mathrm{MHz}$ | 高速模式       |
| 0     | 1    | 1      | 0    | fprs/4  | fw/24  |                                 | (SMC0 = 1) |
| 0     | 1    | 1      | 1    | fexscl0 | fw/18  | 6.4 MHz                         |            |
| 1     | 0    | ×      | ×    | 禁止设置    |        |                                 |            |
| 1     | 1    | 0      | ×    | fprs/2  | fw/12  | $4.00\sim4.19~\mathrm{MHz}$     | 高速模式       |
| 1     | 1    | 1      | 0    | fprs/4  | fw/12  |                                 | (SMC0 = 1) |
| 1     | 1    | 1      | 1    | 禁止设置    |        |                                 | _          |

注意事项: 允许操作(通过设置 IIC 控制寄存器 0 (IICC0)的第 7 位(IICE0)为 1 实现)前,使用 CLX0、SMC0、CL01 和 CL00 决定 I<sup>2</sup>C 的传送时钟频率。若改变传送时钟频率,必须把 IICE0 清零。

**备注:** 1. ×: 不必考虑

**2.** fprs: 外围硬件时钟频率

3. fexsclo: 来自 EXSCLO 引脚的外部时钟频率

## (7) 端口模式寄存器 6 (PM6)

此寄存器可以按位设置端口6的输入/输出操作模式。

当 P60/SCL0 引脚用于时钟 I/O 同时将 P61/SDA0 引脚用于串行数据 I/O 时,将 PM60 和 PM61 清零,且将 P60 和 P61 的输出锁存器清零。

在设置输出模式之前应将 IICE0 (IIC 控制寄存器 0 (IICC0)的第 7 位)设为 1, 这是因为当 IICE0 为 0 时, P60/SCL0 和 P61/SDA0 引脚输出低电平(恒定)。

可由 1 位或 8 位存储器操作指令设置 PM6。

复位信号的产生将 PM6 设置为 FFH。

# 图 18-10 端口模式寄存器 6 (PM6)的格式

地址: FF26H 复位后: FFH R/W 符号 7 6 5 4 3 2 1 0 PM6 PM67 PM66 PM65 PM64 PM63 PM62 PM61 PM60

|   | PM6n | P6n 引脚 I/O 模式选择 (n = 0 $\sim$ 7) |  |  |  |  |
|---|------|----------------------------------|--|--|--|--|
| ſ | 0    | 输出模式 (输出缓冲器打开)                   |  |  |  |  |
|   | 1    | 输入模式 (输出缓冲器关闭)                   |  |  |  |  |

# 18.4 I<sup>2</sup>C 总线模式功能

数据输入

## 18.4.1 引脚配置

串行时钟引脚 (SCL0)和串行数据总线引脚(SDA0)配置如下。

- (1) SCL0.......此引脚用于串行时钟的输入和输出。
  - 此引脚是主设备和从设备的 N-ch 漏极开路输出。该输入是施密特(Schmitt)输入。
- (2) SDA0......此引脚用于串行数据的输入和输出。
  - 此引脚是主设备和从设备的 N-ch 漏极开路输出。该输入是施密特(Schmitt)输入。

由于串行时钟线和串行数据总线的输出都是 N-ch 漏极开路输出,因此需要一个外部上拉电阻。

从设备  $V_{\text{DD}}$ 主设备 SCL0 SCL0 时钟输出 -(时钟输出)  $V_{\text{DD}}$ Vss <del>///</del> (时钟输入) ► 时钟输入 SDA0 SDA0 数据输出 数据输出 Vss /// <del>///</del> Vss

- 数据输入

图 18-11 引脚配置框图

# 18.5 I<sup>2</sup>C 总线定义和控制方法

以下描述了  $I^2C$  总线的串行数据通信格式和  $I^2C$  总线使用的信号。 图 18-12 显示了通过  $I^2C$  串行数据总线的"起始条件","地址","数据"和"停止条件"等信号输出时的传送时序。

图 18-12 I<sup>2</sup>C 总线串行数据传送时序

主设备产生起始条件、从设备地址和停止条件。

应答信号(ACK)可以由主设备或者从设备产生(通常,由接收8位数据的设备输出)。

主设备持续输出串行时钟(SCL0)。但在从设备中,可以延长SCL0的低电平阶段同时可以插入等待时间。

## 18.5.1 起始条件

SCLO 引脚处于高电平且 SDAO 引脚从高电平变为低电平时,满足起始条件。当启动串行传送时,SCLO 引脚和 SDAO 引脚的起始条件是由主设备产生并发给从设备的信号。当使用从设备时,可以检测到起始条件。



图 18-13 起始条件

检测到停止条件(SPD0: IIC 状态寄存器 0 (IICS0)的第 0 位=1)后,IIC 控制寄存器 0(IICC0)的第 1 位(STT0)被设置 (为 1)时,输出一个起始条件。检测到起始条件时,IICS0 的第 1 位(STD0)被设置(为 1)。

#### 18.5.2 地址

地址由起始条件之后的7位数据指定。

一个地址是一个输出的 **7** 位数据段,用于选择一个通过总线与主设备相连的从设备。因此,通过总线相连的每个从设备必须有一个唯一的地址。

从设备包括具有以下功能的硬件: 检测起始条件,检查 7 位地址数据是否与存储在从设备地址寄存器 0(SVA0)中的数据匹配。如果地址数据和 SVA0 的值匹配,则该从设备将被选中且与主设备通信,直到主设备产生一个起始条件或停止条件。



注: 如果在从设备操作期间接收到的是数据而不是本地地址或扩展码时,则 INTIIC0 不会发出。

将从设备地址和第8位(用于指示传送方向(如18.5.3传送方向指示中所描述的))一起写入IIC移位寄存器 0(IIC0)并且输出。接收到的地址写入IIC0。

将从设备地址分配给 IIC0 的高 7 位。

#### 18.5.3 传送方向指示

除了7-位地址数据之外,主设备还发送1位数据用于指示传送方向。

当传送方向指示位的值为"0"时,表示主设备正向从设备传送数据。当传送输方向指示位的值为"1"时,表示主设备正接收来自从设备的数据。

图 18-15. 传送方向指示

注: 如果在从设备操作期间接收到的是数据而不是本地地址或扩展码时,则 INTIICO 不会发出。

#### 18.5.4 应答信号 (ACK)

ACK 信号用于检测处于发送方和接收方的串行数据的状态。

当接收方收到 8 位数据后将返回一个 ACK 信号。

发送方通常在发送了 8 位数据后接收到 ACK 信号。当 ACK 信号从接收方返回时,认为已正确接收并继续之后的处理。是否检测到 ACK 信号可以通过 IIC 状态寄存器 0(IICS0)的第 2 位(ACKD0)进行检测。

主设备接收到最后一个数据项时,不再返回 ACK 信号而是产生一个停止条件。如果从设备在接收到数据后未返回 ACK 信号,主设备将输出一个停止条件或重启条件并且停止传送。如果未返回 ACK 信号,可能是如下原因。

- <1> 接收操作没有正常进行。
- <2> 接收到最后一个数据项。
- <3> 由地址指示的接收方不存在。

要产生 ACK 信号,接收方必须在第 9 个时钟时使 SDA0 线变为低电平(表示正常接收)。

可通过设置 IIC 控制寄存器 0(IICC0)的第 2 位(ACKE0)为 1,自动产生 ACK 信号。IICS0 寄存器的第 3 位(TRC0)可被数据的第 8 位(紧接着 7 位地址信息)设置。通常,设置 ACKE0=1 用于接收 (TRC0 = 0)。

如果一个从设备在接收(TRC0 = 0)期间不再收到任何数据或者不再需要下一个数据项,则从设备必须通过将 ACKE0 清零通知主设备,这样它就不会再收到任何数据。

接收(TRC0 = 0)期间,当主设备不需要下一个数据项时,必须将 ACKE0 清零,这样就不会产生 ACK。在这种方式下,主设备通知作为发送方的从设备,不再需要其他数据(发送过程将停止)。

# 图 18-16 ACK 信号



接收到本地地址时,无论 ACKEO 的值是多少,都将自动产生 ACK 信号。当接收到一个非本地地址时,则不产生 ACK 信号(NACK)。

接收到扩展码时,如果  $\overline{ACKE0}$  预先设为 1,则将产生  $\overline{ACK}$  信号。接收到数据时如何产生  $\overline{ACK}$  信号,将根据等待时序的设置而变化。

- 当选择 8 时钟等待状态时 (IICCO 寄存器的第 3 位(WTIMO)= 0): 退出等待状态前通过将 ACKEO 设为 1,在 SCLO 引脚第 8 个时钟的下降沿产生 ACK 信号。
- 当选择 9 时钟等待状态时 (IICCO 寄存器的第 3 位(WTIM0)= 1): 通过预先设置 ACKEO 为 1 产生 ACK 信号。

## 18.5.5 停止条件

SCL0 引脚处于高电平时,将 SDA0 引脚从低电平变为高电平可以产生一个停止条件。

停止条件是一个信号,它在串行传送操作结束时由主设备产生并发送给从设备。当作为从设备使用时,可以检测到停止条件。

图 18-17 停止条件



IIC 控制寄存器 0(IICC0)的第 0 位(SPT0)设为 1 时,会产生一个停止条件。当检测到停止条件时,IIC 状态寄存器 0(IICS0)的第 0 位(SPD0)被设为 1 且当 IICC0 的第 4 位(SPIE0)被设为 1 时产生 INTIIC0。

## 18.5.6 等待

等待状态用来通知通信另一方,设备(主设备或从设备)正准备发送或者接收数据(即处于等待状态)。

设置 SCL0 引脚为低电平,通知通信另一方设备已进入等待状态。当主设备和从设备的等待状态被取消时,下一个数据传送才能开始。

## 图 18-18 等待 (1/2)

(1) 当主设备输出第 9 个时钟后等待而从设备输出第 8 个时钟后等待时(主设备发送,从设备接收,同时 ACKE0 = 1)



## 图 18-18 等待 (2/2)

# (2) 当主和从设备都输出第 9 个时钟后等待时(主设备发送,从设备接收,同时 ACKE0 = 1)



**备注:** ACKE0: IIC 控制寄存器 0(IICC0)的第 2 位 WREL0: IIC 控制寄存器 0(IICC0)的第 5 位

根据 IIC 控制寄存器 0(IICC0)的第3位(WTIM0)的设置,自动产生等待状态。

通常,当 IICC0 的第 5 位(WREL0)设置为 1 时或者在将 FFH 写入 IIC 移位寄存器 0(IIC0)时,接收方取消等待状态,而当数据写入 IIC0 时,发送方取消等待状态。

主设备也能通过以下任何一种方法取消等待状态。

- 通过把 IICC0 的第 1 位(STT0)设为 1
- 通过把 IICC0 的第 0 位(SPT0)设为 1

#### ★ 18.5.7 取消等待

 $I^2C$  通常通过如下处理方式取消一个等待状态。

- 把数据写入 IIC 移位寄存器 0(IIC0)
- 设置 IIC 控制寄存器 0(IICC0) 的第 5 位(WREL0) (取消等待)
- 设置 IICC0 寄存器的第 1 位 (STT0) (产生起始条件)<sup>性</sup>
- 设置 IICC0 寄存器的第 0 位 (SPT0) (产生停止条件)<sup>2</sup>

#### 注: 仅用于主设备

当执行以上取消等待处理过程时, I<sup>2</sup>C 取消等待状态且恢复通信。

通过向 IIC0 写数据来取消等待状态并发送数据 (包括地址)。

通过设置 IIC 控制寄存器 0(IICC0)的第5位(WREL0)为1,可在取消等待状态之后接收数据,或完成数据发送操作。

设置 IICC0 的第 1 位(STT0)为 1,可在取消一个等待状态之后产生一个重启条件。

设置 IICC0 的第 0 位(SPT0)为 1,可在取消一个等待状态之后产生一个停止条件。

对于一个等待状态只能执行一次取消操作。

例如,如果通过设置 WRELO 为 1 在取消等待状态之后将数据写入 IICO,则可能一个不正确的值输出到 SDAO, 这是 因为改变 SDAO 线的时序和 IICO 写操作时序相冲突。

除此以外,如果通信已放弃时 IICEO 被清零,则停止通信,这样可以取消等待状态。

如果 I<sup>2</sup>C 总线由于噪音产生死锁,则通过设置 IICC0 的第 6 位(LREL0)可以保存通信处理内容,这样等待状态便可以取消。

#### 18.5.8 中断请求 (INTIIC0)产生时序和等待控制

IIC 控制寄存器 0(IICC0)的第3位(WTIM0)的设置决定 INTIIC0产生时序和相应的等待控制,如表18-3所示。

| WTIMO |                   | 从设备操作期间           | -               |    | 主设备操作期间 | -    |
|-------|-------------------|-------------------|-----------------|----|---------|------|
|       | 地址                | 数据接收              | 数据发送            | 地址 | 数据接收    | 数据发送 |
| 0     | 9 <sup>牲1,2</sup> | 8 <sup>2</sup> 2  | 8 <sup>2</sup>  | 9  | 8       | 8    |
| 1     | 9 <sup>推1,2</sup> | 9 <sup>26 2</sup> | 9 <sup>推2</sup> | 9  | 9       | 9    |

表 18-3 INTIIC0 产生时序和等待控制

**注:** 1. 仅当有地址与从设备地址寄存器 0(SVA0)设置的地址匹配时,在第 9 个时钟的下降沿产生从设备的 INTIIC0 信号和等待周期。

此时,不论 IICC0 的第 2 位(ACKE0)设置为何值,都将产生 ACK 信号。对于一个接收到扩展码的从设备,在第 8 个时钟的下降沿将产生 INTIIC0。

但是,如果重启之后地址不匹配,将在第9个时钟的下降沿产生INTIICO,但不会产生等待周期。

2. 如果接收地址与从设备地址寄存器 0(SVA0)的内容不匹配,同时也未接收到扩展码,则 INTIIC0 和等待 周期都不会产生。

**备注:** 表中的数字是指串行时钟的时钟信号个数。中断请求和等待控制和这些时钟信号的下降沿同步。

#### (1) 地址发送/接收期间

• 从设备操作: 中断和等待时序取决于以上注 1、2 中所描述的情况,与 WTIM0 位无关。

• 主设备操作: 中断和等待时序在第 9 个时钟的下降沿发生,与 WTIM0 位无关。

## (2) 数据接收期间

• 主/从设备操作: 中断和等待时序取决于 WTIM0 位。

#### (3) 数据发送期间

• 主/从设备操作: 中断和等待时序取决于 WTIM0 位。

#### (4) 等待取消的方法

四种取消等待方法如下所示。

- 向 IIC 移位寄存器 0 (IIC0)写入数据
- 设置 IIC 控制寄存器 0(IICC0)的第5位 (WREL0) (取消等待)
- 设置 IICC0 寄存器的第 1 位 (STT0) (产生起始条件)<sup>2</sup>
- 设置 IICC0 寄存器的第 0 位 (SPT0) (产生停止条件)<sup>t</sup>

注: 仅用于主设备。

当选择了一个8-时钟等待时(WTIMO = 0),必须先决定是否产生 ACK 信号,再考虑取消等待。

## (5) 停止条件的检测

当检测到一个停止条件时(仅当 SPIE0 = 1), INTIIC0 将会产生。

#### 18.5.9 地址匹配的检测方法

在  $I^2C$  总线模式下,主设备可以通过发送的从设备地址来选择指定的从设备。

可以通过硬件自动检测到地址匹配。当将一个本地地址设置到从设备地址寄存器 0(SVA0)中且该地址与主设备发送的从设备地址匹配时,或者接收到扩展码时,都将产生一个中断请求(INTIIC0)。

# 18.5.10 错误检测

I<sup>2</sup>C 总线模式下,在数据发送期间通过发送设备的 IIC 移位寄存器(IIC0)捕获串行数据总线(SDA0) 的状态,因此发送前的 IIC0 数据可以用来和已发送的 IIC0 数据比较,以此来实现对发送错误的检测。当比较值不匹配时,可以判断存在一个发送错误。

#### 18.5.11 扩展码

- (1) 当接收地址的高 4 位为 "0000"或"1111"时,代表接收到扩展码的扩展码接收标志(EXC0)被设为 1,并且在第 8 个时钟的下降沿产生中断请求(INTIIC0)。而存放在从设备地址寄存器 0(SVA0)中的本地地址不受影响。
- (2) 如果由一个 10 位地址传送设置 SVA0 为"11110××0"且主设备传送的值为"11110××0",则其结果如下所示。注意在 第 8 个时钟的下降沿产生 INTIIC0。

数据的高 4 位匹配: EXC0 = 1
 7 位数据匹配: COI0 = 1

**备注:** EXCO: IIC 状态寄存器 0(IICSO)的第 5 位 COI0: IIC 状态寄存器 0(IICSO)的第 4 位

(3) 由于中断请求发生之后的处理过程随扩展码之后的数据而有所不同,因此这样的处理过程由软件来执行。如果当一个从设备正在操作时接收到扩展码,那么该从设备(即使它的地址不匹配)也将参与通信。例如,接收到扩展码后,如果不希望目标设备作为从设备来操作,则将 IIC 控制寄存器 0(IICC0)的第 6 位 (LREL0)设为 1,为下一个通信操作设置待机模式。

表 18-4 扩展码位定义

| 从设备地址     | R/W 位 | 描述           |  |
|-----------|-------|--------------|--|
| 0000 000  | 0     | 通用调用地址       |  |
| 0000000 1 |       | 起始字节         |  |
| 0000001 × |       | C-总线地址       |  |
| 0000010 × |       | 为不同总线格式预约的地址 |  |
| 11110XX × |       | 10 位从设备地址规范  |  |

#### 18.5.12 仲裁

当多个主设备同时产生起始条件信号时 (在 STD0 设为 1 之前将 STT0 设为 1),调整时钟数目直至传送数据改变,然后执行主设备间的通信。这种操作称为仲裁。

当有一个主设备仲裁失败时,可通过仲裁失败产生的时序设置 IIC 状态寄存器 0(IICS0)中的仲裁失败标志(ALD0)为 1,同时 SCL0 和 SDA0 线变为高阻抗,从而释放总线。

基于下一个中断请求的时序(第8或第9个时钟,检测到停止条件时等)以及由软件设置 ALD0=1来检测仲裁失败。有关中断请求时序,详见 18.5.17  $I^2$ C 中**断请求(INTIIC0)产生时序**。

**备注:** STD0: IIC 状态寄存器 0 (IICS0)的第 1 位 STT0: IIC 控制寄存器 0 (IICC0)的第 1 位

图 18-19 仲裁时序举例



# 表 18-5 仲裁期间的状态和中断请求产生时序

| 仲裁期间的状态             | 中断请求产生时序                            |
|---------------------|-------------------------------------|
| 地址发送期间              | 字节传送后第8或第9个时钟的下降沿 <sup>推1</sup>     |
| 地址发送后读/写数据          |                                     |
| 扩展码发送期间             |                                     |
| 扩展码发送后读/写数据         |                                     |
| 数据发送期间              |                                     |
| 数据发送之后的 ACK 信号传送期间  |                                     |
| 数据传送期间检测到重启条件时      |                                     |
| 数据传送期间检测到停止条件时      | 停止条件产生时 (当 SPIE0 = 1) <sup>推2</sup> |
| 准备产生重启条件时数据为低电平     | 字节传送后第8或第9个时钟的下降沿 <sup>胜1</sup>     |
| 准备产生重启条件时检测到停止条件    | 停止条件产生时 (当 SPIE0 = 1) <sup>推2</sup> |
| 准备产生停止条件时数据为低电平     | 字节传送后第8或第9个时钟的下降沿 <sup>推1</sup>     |
| 准备产生重启条件时 SCL0 为低电平 |                                     |

**注:** 1. 当 WTIM0 (IIC 控制寄存器 0 (IICC0)的第 3 位) = 1 时,将在第 9 个时钟的下降沿产生一个中断请求。当 WTIM0 = 0 且扩展码的从设备地址已被接收时,将在第 8 个时钟的下降沿产生一个中断请求。

2. 如果可以产生仲裁,则设置 SPIE0 = 1,进行主设备操作。

备注: SPIE0: IIC 控制寄存器 0 (IICC0)的第 4 位

#### 18.5.13 唤醒功能

 $I^2C$  总线从设备唤醒功能是,在接收到本地地址及扩展码时产生一个中断请求信号(INTIICO)。

此功能通过在地址不匹配时禁止产生不必要的 INTIICO 信号,使处理更加有效。

当检测到一个起始条件时,设置唤醒待机模式。仲裁失败可能将主设备(已产生起始条件)转变为从设备,如果因此而发送地址时,则该唤醒待机模式有效。

可是, 当检测到停止条件时, 无论是否有唤醒功能, 都设置 IIC 控制寄存器 0 (IICC0) 的第 4 位(SPIE0), 这将决定是否允许或禁止中断请求。

#### 18.5.14 通信预约

## (1) 允许使用通信预约功能时(IIC 标志寄存器 0(IICF0)的第 0 位(IICRSV) = 0)

如果要启动当前不使用总线的主设备通信,可以使用通信预约功能,在总线释放时允许发送一个起始条件信号。有两种不使用总线时的模式。

- 当仲裁结果不是主/从设备操作时
- 当接收到扩展码且禁止从设备操作时(不返回 ACK 信号且 IIC 控制寄存器 0 (IICC0) 的第 6 位(LREL0)被设置为 1 时释放总线)。

如果总线未使用时(检测到停止条件后)IICC0 的第 1 位(STT0) 被设为 1,则自动产生一个起始条件并且设置等待状态。

如果在 IICC0 的第 4 位(SPIE0)被设为 1 之后将地址写入 IIC 移位寄存器 0 (IIC0),并且通过总线释放(检测停止状态)产生中断请求信号(INTIIC0)来检测该地址,则设备将以主设备方式自动开始通信。在检测到停止条件前写入 IIC0 的数据是无效的。

当 STT0 已被设为 1 时,操作模式(作为起始条件或作为通信预约)取决于总线状态。

- 如果总线已被释放......产生一个起始条件

STT0 设为 1 且经历了等待时间后,使用 MSTS0(IIC 状态寄存器 0 (IICS0)的第7位)检查是否进行通信预约操作。

应通过软件设置的等待周期见表 18-6。

表 18-6 等待周期

| CLX0 | SMC0 | CL01 | CL00 | 等待周期    |
|------|------|------|------|---------|
| 0    | 0    | 0    | 0    | 46 个时钟  |
| 0    | 0    | 0    | 1    | 86 个时钟  |
| 0    | 0    | 1    | 0    | 172 个时钟 |
| 0    | 0    | 1    | 1    | 34 个时钟  |
| 0    | 1    | 0    | 0    | 30个时钟   |
| 0    | 1    | 0    | 1    |         |
| 0    | 1    | 1    | 0    | 60 个时钟  |
| 0    | 1    | 1    | 1    | 12个时钟   |
| 1    | 1    | 0    | 0    | 18个时钟   |
| 1    | 1    | 0    | 1    |         |
| 1    | 1    | 1    | 0    | 36 个时钟  |

图 18-20 显示通信预约时序。

×

图 18-20. 通信预约时序



通过总线控制由主设备产生

**备注:** IIC0: IIC 移位寄存器 0

STT0: IIC 控制寄存器 0 (IICC0)的第 1 位 STD0: IIC 状态寄存器 0 (IICS0)的第 1 位 SPD0: IIC 状态寄存器 0 (IICS0)的第 0 位

通过以下时序接受通信预约。IIC 状态寄存器 0 (IICSO)的第 1 位(STDO)设为 1 之后,可以通过在检测到停止条件之前设置 IIC 控制寄存器 0 (IICCO)的第 1 位(STTO)为 1 来进行通信预约。



图 18-21 接受通信预约的时序

图 18-22 显示通信预约方案。

图 18-22. 通信预约方案



注: 当产生一个停止条件中断请求时,通信预约执行对 IIC 移位寄存器 0 (IIC0)的写操作。

**备注:** STT0: IIC 控制寄存器 0 (IICC0)的第 1 位

MSTS0: IIC 状态寄存器 0 (IICS0)的第7位

IIC0: IIC 移位寄存器 0

#### (2) 当禁止使用通信预约功能时 (IIC 标志寄存器 0 (IICF0)的第 0 位(IICRSV) = 1)

如果在总线通信期间,总线未使用时将 IIC 控制寄存器 0 (IICC0) 的第 1 位(STT0)设置为 1,则该请求会被拒绝并且不产生起始条件。下列两种状态包括了总线未使用时的情况。

- 当仲裁结果不是主/从设备操作时
- 接收到一个扩展码且禁止从设备操作时 (不返回 ACK 信号且 IIC 控制寄存器 0 (IICC0) 的第 6 位(LREL0)被设置为 1 时释放总线)

通过检查 STCF(IICF0 的第 7 位)来确认是产生了起始条件还是请求被拒绝。设置 STT0 = 1 后,直到 STCF 被设置为 1 时,必须满足表 18-7 所示的时间。因此,必须通过软件确保等待时间。

\*

表 18-7 等待周期

| CL01 | CL00 | 等待周期   |
|------|------|--------|
| 0    | 0    | 6个时钟   |
| 0    | 1    | 6个时钟   |
| 1    | 0    | 12 个时钟 |
| 1    | 1    | 3个时钟   |

#### 18.5.15 其他注意事项

#### (1) 当 STCEN (IIC 标志寄存器 0 (IICF0)的第 1 位) = 0 时

在允许 I<sup>2</sup>C 操作(IICE0 = 1)后,无论总线的实际状态如何都可以识别总线通信状态(IICBSY (IICF0 的第 6 位) = 1)。从检测到非停止条件模式变为主设备通信模式时,首先产生一个停止条件以释放总线,然后进行主设备通信。

当使用多个主设备时,如果总线未被释放(没有检测到停止条件),则不能进行主设备通信。按下列步骤产生停止条件。

- <1> 设置 IIC 时钟选择寄存器 0 (IICCL0)。
- <2> 设置 IIC 控制寄存器 0 (IICC0) 的第7位(IICE0)为 1。
- <3> 设置 IICC0 的第 0 位(SPT0)为 1。

#### (2) 当 STCEN = 1

在允许  $I^2C$  操作(IICE0 = 1)后,无论总线的实际状态如何都可以识别总线通信状态(IICBSY (IICF0 的第 6 位) = 1)。要产生第一个起始条件 (STT0 (IIC 控制寄存器 0 (IICC0)的第 1 位) = 1),必须确认总线已被释放,以免干扰其他通信。

#### (3) 如果其他 I2C 通信已经进行

如果 SDA0 引脚为低电平同时 SCL0 引脚为高电平时允许  $I^2$ C 操作,且设备已进行通信,则  $I^2$ C 的宏可以识别 SDA0 引脚已经变为低电平(检测一个起始条件)。如果此时总线上的值被识别为一个扩展码,则返回 ACK 信号,但这会干扰其他  $I^2$ C 通信。为了避免这种情况,可按下列步骤启动  $I^2$ C。

- <1> 当检测到停止条件时,将 IICC0 的第 4 位(SPIE0)清零,禁止产生中断请求信号(INTIIC0)。
- <2> 设置 IICC0 的第7位(IICE0)为1,允许I<sup>2</sup>C的操作。
- <3> 等待对起始条件的检测。
- <4> ACK 信号返回之前(设置 IICE0 为 1 之后的 4 到 80 个时钟)设置 IICC 的第 6 位 (LREL0) 为 1,强行禁止检测。
- ★ (4) 允许操作之前(IICE0 = 1)通过使用 SMC0, CL01, CL00 (IICL0 的第 3, 1 和 0 位)和 CLX0 (IICX0 的第 0 位)决定传送时钟频率。要改变传送时钟频率,必须清零 IICE0。

- ★ (5) 在对 STT0 和 SPT0 (IICC0 的第 1 和第 0 位)设置之后和清零之前,禁止再次设置。
  - (6) 当预约发送时,设置 SPIE0 (IICL0 的第 4 位)为 1,以允许在检测到停止条件时产生中断请求。中断请求产生后,将通信数据写入 IIC0,传送过程开始。如果检测到停止条件时不产生中断请求,设备将处于等待状态,因为开始通信时不产生中断请求。但是,由软件检测 MSTS0 (IICS0 的第 7 位)时不必设置 SPIE0 为 1。

## 18.5.16 通信操作

## ★ (1) 主设备操作 (单主设备系统)



图 18-23. 主设备操作流程图 (单主设备系统)

注:根据正在通信的产品规范释放(SCL0 和 SDA0 引脚 = 高电平)I<sup>2</sup>C 总线。如果 EEPROM 向 SDA0 引脚输出一个低电平,例如,设 SCL0 引脚为输出端口模式,且从输出端口输出一个时钟脉冲直到 SDA0 引脚持续处于高电平。

备注: 遵照正在通信的产品规范,注意发送和接收的格式。

# ★(2) 主设备操作(多主设备系统)

图 18-24. 主设备操作流程图(多主设备系统) (1/3)



**注:**确认总线已释放了(CLD0 位 = 1, DAD0 位 = 1)指定的一段时间(如,一帧的周期)。如果 SDA0 引脚持续处于低电平,可以根据正在使用的产品规范决定是否释放(SCL0 和 SDA0 引脚 = 高电平) $I^2$ C 总线。

## 图 18-24 主设备操作流程图(多主设备系统) (2/3)







图 18-24 主设备操作流程图(多主设备系统) (3/3)

# 备注:

- 1. 遵照正在通信的产品规范,注意发送和接收的格式。
- 2. 如果在多主设备系统中作为一个主设备使用时,则应在每次中断 INTIIC0 发生后读取 MSTS0 位来检查 仲裁结果。
- 3. 如果在多主设备系统中作为一个从设备使用时,则通过在每次中断 INTIIC0 发生后使用 IICS0 和 IICF0 寄存器来检查状态,并决定下一步的处理。

#### (3) 从设备操作

从设备操作过程如下所示。

基本上,从设备操作是由事件驱动的。因此,必须执行 INTIICO 中断处理过程(该中断处理过程必须完全改变操作状态例如通信时的停止条件检测)。

在下列说明中,假定数据通信不支持扩展码。同时假定 INTIICO 中断服务只执行状态转换处理过程,且实际数据通信过程由主程序执行。



因此,设置以下3个标志,并传递给主程序而不是INTIICO,这样可以执行数据通信处理过程。

#### <1> 通信模式标志

此标志指示下列两种通信状态。

• 清除模式: 未进行数据通信

• 通信模式: 进行数据通信(从有效地址检测到停止条件检测,不检测来自主设备的 ACK 信

号,地址不匹配)

#### <2> 准备标志

此标志表示允许进行数据通信。它的功能和普通数据通信的 INTIICO 中断相同。通过中断服务可以设置此标志,通过主程序可以将该标志清零。通信启动时,可由中断服务将此标志清零。但是,在发送第一个数据时不能由中断服务设置准备标志。因此,发送第一个数据时该标志未清零 (认为地址匹配是下一个数据发送请求)。

#### <3> 通信方向标志

此标志指示通信方向。它的值与 TRC0 相同。

从设备操作的主程序处理过程说明如下。

启动串行接口 IICO 且等待直到允许通信。当允许通信时,通过使用通信模式标志和准备标志来执行通信 (由中断来执行停止条件和起始条件的处理。这里,通过标志来检查状态)。

重复发送操作直到主设备不再返回 ACK 信号。如果没有从主设备返回 ACK 信号,则通信结束。

对于接收操作,则要接收一定量的数据。通信完成时,ACK 信号不作为下一个数据返回。此后,主设备产生一个停止条件或重启条件。使用这种方法可从通信状态退出。

### 图 18-25 从设备操作流程图 (1)



备注: 遵照正在通信的产品规范,注意发送和接收的格式。

以下示例说明了从设备 INTIICO 中断处理过程 (处理中假设不使用扩展码)。INTIICO 中断检查状态,同时执行下列操作。

- <1> 若发出停止条件则通信停止。
- <2> 若发出起始条件,检查地址并在地址不匹配时结束通信。如果地址匹配,则设置通信模式,取消等待,且处理过程从中断返回(准备标志清零)。
- <3> 对于数据发送/接收,仅需设置准备标志。处理过程从中断返回,同时  $I^2C$  总线保持等待状态。

**备注:** 以上<1>  $\sim$  <3> 与图 18-26 从设备操作流程图(2)中<1>  $\sim$  <3> 相对应。

#### 图 18-26 从设备操作流程图(2)



# 18.5.17 I<sup>2</sup>C 中断请求 (INTIIC0)产生时序

以下显示了发送或接收数据的时序和中断请求信号 INTIICO 产生时序,以及 INTIICO 信号产生时 IICSO 寄存器的值。

**备注:** ST: 起始条件

AD6 to AD0: 地址

R/W: 传送方向指示

ACK: 应答 D7 to D0: 数据 SP: 停止条件

#### (1) 主设备操作

# (a) 开始~地址~数据~数据~停止(发送/接收)

(i) 当 WTIM0 = 0



▲1: IICS0 = 1000×110B

▲2: IICS0 = 1000×000B

▲3: IICS0 = 1000×000B (设置 WTIM0 为 1)<sup>±</sup>

▲4: IICS0 = 1000××00B (设置 SPT0 为 1) #

△5: IICS0 = 00000001B

注: 设置 WTIMO 为 1 并改变产生 INTIICO 中断请求信号的时序,可以产生一个停止条件。

**备注:** ▲: 始终产生

△: 仅当 SPIE0 = 1 时产生

x: 不必考虑

(ii) 当 WTIM0 = 1



▲1: IICS0 = 1000×110B

▲2: IICS0 = 1000×100B

▲3: IICS0 = 1000××00B (设置 SPT0 为 1)

△4: IICS0 = 00000001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

# (b) 开始 ~ 地址 ~ 数据 ~ 开始 ~ 地址 ~ 数据 ~ 停止 (重启)

(i) 当 WTIM0 = 0



(ii) 当 WTIM0 = 1



#### (c) 开始 ~ 代码 ~ 数据 ~ 数据 ~ 停止 (发送扩展码)

(i) 当 WTIM0 = 0



▲1: IICS0 = 1010×110B

▲2: IICS0 = 1010×000B

▲3: IICS0 = 1010×000B (设置 WTIM0 为 1)<sup>±</sup>

▲4: IICS0 = 1010××00B (设置 SPT0 为 1)

△5: IICS0 = 00000001B

注: 设置 WTIMO 为 1 并改变 INTIICO 产生中断请求信号的时序,可以产生一个停止条件。

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

x: 不必考虑

(ii) 当 WTIM0 = 1



▲1: IICS0 = 1010×110B

▲2: IICS0 = 1010×100B

▲3: IICS0 = 1010××00B (设置 SPT0 为 1)

△4: IICS0 = 00001001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

#### (2) 从设备操作 (接收从设备地址数据)

# (a) 开始 ~ 地址 ~ 数据 ~ 数据 ~ 停止

(i) 当 WTIM0 = 0



▲1: IICS0 = 0001×110B ▲2: IICS0 = 0001×000B

▲3: IICS0 = 0001×000B

△4: IICS0 = 00000001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

x: 不必考虑

(ii) 当 WTIM0 = 1



▲1: IICS0 = 0001×110B

▲2: IICS0 = 0001×100B

▲3: IICS0 = 0001××00B

△4: IICS0 = 00000001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

#### (b) 开始 ~ 地址 ~ 数据 ~ 开始 ~ 地址 ~ 数据 ~ 停止

(i) 当 WTIM0 = 0 (重启后,与 SVA0 匹配)



(ii) 当 WTIM0 = 1 (重启后,与 SVA0 匹配)



#### (c) 开始 ~ 地址 ~ 数据 ~ 开始 ~ 代码 ~ 数据 ~ 停止

(i) 当 WTIM0 = 0 (重启后,地址不匹配 (= 扩展码))



(ii) 当 WTIMO = 1 (重启后, 地址不匹配 (= 扩展码))



# (d) 开始 $\sim$ 地址 $\sim$ 数据 $\sim$ 开始 $\sim$ 地址 $\sim$ 数据 $\sim$ 停止

(i) 当 WTIM0 = 0 (重启后, 地址不匹配 (= 非扩展码))



(ii) 当 WTIM0 = 1 (重启后, 地址不匹配 (= 非扩展码))



#### (3) 从设备操作 (当接收到扩展码时)

接收到扩展码时,设备总是参与通信。

# (a) 开始 ~ 代码 ~ 数据 ~ 数据 ~ 停止

(i) 当 WTIM0 = 0



▲1: IICS0 = 0010×010B

▲2: IICS0 = 0010×000B

▲3: IICS0 = 0010×000B

△4: IICS0 = 00000001B

**备注:** ▲: 始终产生

△: 仅当 SPIE0 = 1 时产生

x: 不必考虑

(ii) 当 WTIM0 = 1



▲1: IICS0 = 0010×010B

▲2: IICS0 = 0010×110B

▲3: IICS0 = 0010×100B

▲4: IICS0 = 0010××00B

△5: IICS0 = 00000001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

#### (b) 开始 $\sim$ 代码 $\sim$ 数据 $\sim$ 开始 $\sim$ 地址 $\sim$ 数据 $\sim$ 停止

(i) 当 WTIM0 = 0 (重启后,与 SVA0 匹配)



(ii) 当 WTIM0 = 1 (重启后,与 SVA0 匹配)



#### (c) 开始 ~ 代码 ~ 数据 ~ 开始 ~ 代码 ~ 数据 ~ 停止

(i) 当 WTIM0 = 0 (重启后,接收到扩展码)



(ii) 当 WTIM0 = 1 (重启后,接收到扩展码)



#### (d) 开始 ~ 代码 ~ 数据 ~ 开始 ~ 地址 ~ 数据 ~ 停止

(i) 当 WTIM0 = 0 (重启后, 地址不匹配 (= 非扩展码))



(ii) 当 WTIM0 = 1 (重启后, 地址不匹配 (= 非扩展码))



#### (4) 未进行通信时的操作

(a) 开始 ~ 代码 ~ 数据 ~ 数据 ~ 停止

| ST      | AD6 to AD0   | R/W    | ACK    | D7 to D0 | ĀCK | D7 to D0 | ACK | SP |
|---------|--------------|--------|--------|----------|-----|----------|-----|----|
|         |              |        |        |          |     |          |     | Δ  |
|         |              |        |        |          |     |          |     |    |
| 1: IICS | 50 = 0000000 | )1B    |        |          |     |          |     |    |
| 备注      | · Δ: 仅       | 当 SPII | Ξ0 = 1 | 时产生      |     |          |     |    |

# (5) 发生仲裁失败时的操作 (仲裁失败后作为从设备操作)

★ 在多主设备系统中当一个设备作为主设备使用时,可在每次中断请求信号 INTIICO 产生时读取 MSTSO 位来检查 仲裁结果。

# (a) 发送从设备地址数据期间发生仲裁失败时

(i) 当 WTIM0 = 0



### (ii) 当 WTIM0 = 1



▲1: IICS0 = 0101×110B ▲2: IICS0 = 0001×100B ▲3: IICS0 = 0001×00B △4: IICS0 = 00000001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

x: 不必考虑

# (b) 发送扩展码期间发生仲裁失败时

(i) 当 WTIM0 = 0



▲1: IICS0 = 0110×010B

▲2: IICS0 = 0010×000B

▲3: IICS0 = 0010×000B

△4: IICS0 = 00000001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

(ii) 当 WTIM0 = 1



▲1: IICS0 = 0110×010B ▲2: IICS0 = 0010×110B ▲3: IICS0 = 0010×100B ▲4: IICS0 = 0010×00B △5: IICS0 = 00000001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

x: 不必考虑

# (6) 发生仲裁失败时的操作 (仲裁失败后不进行通信)

★ 在多主设备系统中当一个设备作为主设备使用时,可在每次中断请求信号 INTIIC0 产生时读取 MSTS0 位来检查 仲裁结果。

### (a) 发送从设备地址数据期间发生仲裁失败时 (当 WTIM0 = 1)



# (b) 发送扩展码期间发生仲裁失败时

▲1: IICS0 = 0110×010B 通过软件设置 LREL0 = 1 △2: IICS0 = 00000001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

x: 不必考虑

#### (c) 发送数据期间发生仲裁失败时

(i) 当 WTIM0 = 0



▲1: IICS0 = 10001110B ▲2: IICS0 = 01000000B △3: IICS0 = 00000001B

**备注:** ▲: 始终产生

Δ: 仅当 SPIE0 = 1 时产生

(ii) 当 WTIM0 = 1



# (d) 数据传输期间由于重启条件导致仲裁失败时

(i) 非扩展码 (例: 与 SVA0 不匹配)



#### (ii) 扩展码



### (e) 数据传送期间由于停止条件导致仲裁失败时



#### (f) 要产生重启条件时,由于低电平数据导致仲裁失败时

★ (i) 当 WTIM0 = 0



(ii) 当 WTIM0 = 1



#### (g) 要产生重启条件时,由于停止条件导致仲裁失败时

(i) 当 WTIM0 = 0



(ii) 当 WTIM0 = 1



#### (h) 要产生停止条件时,由于低电平数据导致仲裁失败时

★ (i) 当 WTIM0 = 0



(ii) 当 WTIM0 = 1



# 18.6 时序图

使用  $I^2C$  总线模式时,主设备通过串行总线输出一个地址来选择一个从设备作为它的通信伙伴。

输出从设备地址后,主设备发送 TRC0 位(IIC 状态寄存器 0 (IICS0)的第3位),用于指定数据传送方向,然后开始与从设备进行串行通信。

图 18-27 和 18-28 表示了数据通信的时序图。

IIC 移位寄存器 0 (IIC0)的移位操作和串行时钟(SCL0)的下降沿同步。将发送数据传入 SO0 锁存器并通过 SDA0 引脚 输出(MSBfirst)。

在 SCL0 的上升沿通过 SDA0 引脚输入的数据被捕捉到 IIC0 寄存器。

# 图 18-27. 主设备至从设备的通信举例 (当主设备和从设备都选择 9-时钟等待时) (1/3)

# (1) 起始条件 ~~ 地址



注: 将"FFH"写入 IIC0 或设置 WREL0,可以取消从设备的等待状态。

# 图 18-27 主设备至从设备的通信举例 (当主设备和从设备都选择 9-时钟等待时) (2/3)

# (2) 数据



注:将"FFH"写入 IIC0 或设置 WREL0,可以取消从设备的等待状态。

#### \*

# 图 18-27 主设备至从设备的通信举例 (当主设备和从设备都选择 9-时钟等待时) (3/3)

# (3) 停止状态



注: 将"FFH"写入 IIC0 或设置 WREL0,可以取消从设备的等待状态。

# 图 18-28. 从设备至主设备通信举例 (当主设备选择 8-时钟等待,从设备选择 9-时钟等待时) (1/3)

# (1) 起始条件 ~ 地址



注: 将"FFH"写入 IIC0 或设置 WREL0,可以取消主设备的等待状态。

#### \*

# 图 18-28 从设备至主设备通信举例 (当主设备选择 8-时钟等待,从设备选择 9-时钟等待时) (2/3)

# (2) 数据



注: 将"FFH"写入 IIC0 或设置 WRELO,可以取消主设备的等待状态。

# 图 18-28 从设备至主设备通信举例 (当主设备选择 8-时钟等待,从设备选择 9-时钟等待时) (3/3)

# (3) 停止状态



# 第十九章 乘法器/除法器

# 19.1 乘法器/除法器的功能

乘法器/除法器有以下功能。

- 16 位 × 16 位 = 32 位(乘法)
- 32 位 ÷ 16 位 = 32 位、16 位余数 (除法)

# 19.2 乘法器/除法器的配置

乘法器/除法器包括以下硬件。

表 19-1 乘法器/除法器的配置

| A4 Marie Berlitzie Britzie |                                                                 |  |  |
|----------------------------|-----------------------------------------------------------------|--|--|
| 项目                         | 配置                                                              |  |  |
| 寄存器                        | 余数寄存器 0 (SDR0)<br>乘/除数寄存器 A0 (MDA0H、MDA0L)<br>乘/除数寄存器 B0 (MDB0) |  |  |
| 控制寄存器                      | 乘法器/除法器控制寄存器 0 (DMUC0)                                          |  |  |

乘法器/除法器的框图如图 19-1 所示。



#### (1) 余数寄存器 0 (SDR0)

SDR0 是一个 16 位寄存器,用于存放余数。在乘法模式中该寄存器存储 0,而在除法模式中该寄存器存放操作结果的余数。

可由 8 位或 16 位存储器操作指令读取 SDR0。

复位信号的输入将 SDR0 清零(0000H)。

#### 图 19-2 余数寄存器 0 (SDR0)的格式



注意事项: 1. 在操作期间(乘法器/除法器控制寄存器 0 (DMUC0)的第7位(DMUE)= 1)从 SDR0 中读取的值不确定。 2. 当启动操作时(当 DMUE=1 时), SDR0 被复位。

#### (2) 乘/除数寄存器 A0 (MDA0H、MDA0L)

MDA0 是一个 32 位寄存器,用于在乘法模式中设置 16 位乘数 A 和在除法模式中设置一个 32 位被除数,并存储 32 位的操作结果 (高 16 位: MDA0H、低 16 位: MDA0L)。

#### 图 19-3 乘/除数寄存器 A0 (MDA0H、 MDA0L)的格式



注意事项: 1. 在乘法模式中(乘法器/除法器控制寄存器 0 (DMUC0) = 81H)启动操作时, MDA0H 被清零。

- 2. 在操作期间(乘法器/除法器控制寄存器 0 (DMUC0)的第 7 位(DMUE)= 1)不要修改 MDA0 的值。此时即使执行修改操作,结果也不确定。
- 3. 在操作期间(当 DMUE = 1)从 MDA0 读取的值不确定。

在执行操作时 MDA0 的功能如下。

#### 表 19-2 操作执行期间 MDA0 的功能

| DMUSEL0 | 操作模式 | 设置           | 操作结果      |
|---------|------|--------------|-----------|
| 0       | 除法模式 | 被除数          | 除法结果(商)   |
| 1       | 乘法模式 | 高 16 位: 0    | 乘法结果 (乘积) |
|         |      | 低 16 位: 乘数 A |           |

执行乘法操作期间该寄存器的配置与执行除法操作时的不相同,如下所示。

• 乘法操作期间的寄存器配置

<乗数 A> <乗数 B> <乗积> MDA0(15 
$$\sim$$
 0 位)  $\times$  MDB0(15  $\sim$  0 位) = MDA0(31  $\sim$  0 位)

• 除法操作期间的寄存器配置

当乘法器/除法器控制寄存器 0(DMUC0)的第7位(DMUE)=1时,一旦输入时钟,MDA0 马上获取计算结果。可由8位或16位存储器操作指令设置 MDA0H和 MDA0L。复位信号的输入将 MDA0H和 MDA0L 清零(0000H)。

#### (3) 乘/除数寄存器 B0 (MDB0)

MDB0 用于存储乘法模式中的 16 位乘数 B 和除法模式中的 16 位除数。

可由 8 位或 16 位存储器操作指令设置 MDB0。

复位信号的输入将 MDB0 清零(0000H)。

#### 图 19-4 乘/除数寄存器 B0 (MDB0)的格式



- 注意事项: 1. 在操作期间(乘法器/除法器控制寄存器 0 (DMUC0)的第7位(DMUE)= 1)不要修改 MDB0 的值。此时即使执行修改操作,结果也不确定。
  - 2. 在除法模式中不要对 MDB0 清零(0000H)。如果清零,则存储在 MDA0 与 SDR0 中的操作结果将不确定。

#### 19.3 控制乘法器/除法器的寄存器

乘法器/除法器由乘法器/除法器控制寄存器 0(DMUC0)控制。

#### (1) 乘法器/除法器控制寄存器 0 (DMUC0)

DMUC0是一个8位寄存器,用于控制乘法器/除法器的操作。

可用 1 位或 8 位存储器操作指令设置 DMUC0。

复位信号的输入将 DMUC0 清零(00H)。

#### 图 19-5 乘法器/除法器控制寄存器 0 (DMUC0)的格式

地址: FF68H 复位后: 00H R/W

| 符号    | <7>  | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|-------|------|---|---|---|---|---|---|---------|
| DMUC0 | DMUE | 0 | 0 | 0 | 0 | 0 | 0 | DMUSEL0 |

| DMUE ** | 启动/停止操作 |
|---------|---------|
| 0       | 停止操作    |
| 1       | 启动操作    |

|   | DMUSEL0 | 操作模式(乘法/除法)的选择 |  |  |  |  |  |
|---|---------|----------------|--|--|--|--|--|
| ſ | 0       | 除法模式           |  |  |  |  |  |
|   | 1       | 乘法模式           |  |  |  |  |  |

注: 当 DMUE =1 时, 启动操作。操作结束后 DMUE 被自动清零。

- 注意事项: 1. 如果操作期间(当 DMUE = 1)DMUE 被清零,则操作结果不确定。如果设置了中断标志,在执行清零指令时操作完成,操作结果可以得到保证。
  - 2. 在操作期间(当 DMUE = 1)时,不要修改 DMUSEL0 的值。如果修改了,则存放在乘/除数寄存器 A0 (MDA0)和余数寄存器 0 (SDR0)中的操作结果不确定。
  - 3. 如果在操作期间(当 DMUE = 1)将 DMUE 清零,则停止操作。若要再次执行操作,应对乘/除数寄存器 A0 (MDA0)、乘/除数寄存器 B0 (MDB0)和乘法器/除法器控制寄存器 0 (DMUC0)进行设置,然后启动操作(通过设置 DMUE = 1)。

# 19.4 乘法器/除法器的操作

# 19.4.1 乘法操作

- •初始化设置
- 1. 将操作数赋给乘/除数寄存器 AOL (MDAOL)和乘/除数寄存器 BO (MDBO)。
- 2. 设置乘法器/除法器控制寄存器 0 (DMUC0)的第 0 位 (DMUSEL0) 和第 7 位(DMUE)为 1。启动操作。
- •操作期间
  - 3. 启动操作后经历 16 个内部时钟时,操作完成(操作期间中间数据存于 MDA0L 和 MDA0H 中,因此读取这些寄存器得到的值不确定)。
- •操作结束
  - 4. 操作结果存于 MDA0L 和 MDA0H 中。
  - 5. DMUE 被清零 (操作结束)。
  - 6. 操作结束后,产生中断请求信号(INTDMU)。
- •下一次操作
- 7. 执行下一次乘法操作,要从 19.4.1 乘法操作中的初始化设置开始。
- 8. 执行下一次除法操作,要从19.4.2 除法操作中的初始化设置开始。





#### 19.4.2 除法操作

- •初始化设置
  - 1. 将操作数赋给乘/除数寄存器 A0(MDA0L 和 MDA0H)和乘/除数寄存器 B0(MDB0)。
- 2. 分别设置乘法器/除法器控制寄存器 0(DMUC0)的第 0(DMUSEL0)和第 7 位(DMUE)为 0 和 1。启动操作。
- •操作期间
  - 3. 启动操作后经历 32 个内部时钟时,操作完成(操作期间中间数据存于 MDA0L 和 MDA0H 以及余数寄存器 0(SDR0)中,因此读取这些寄存器得到的值不确定)。
- •操作结束
  - 4. 操作结果存于 MDA0L、MDA0H 和 SDR0 中。
  - 5. DMUE 被清零(操作结束)。
  - 6. 操作结束后,产生中断请求信号(INTDMU)。
- •下一次操作
- 7. 执行下一次乘法操作,要从 19.4.1 乘法操作中的初始化设置开始。
- 8. 执行下一次除法操作,要从 19.4.2 除法操作中的初始化设置开始。





# 第二十章 中断功能

# 20.1 中断功能的类型

可分为以下两种类型:

# (1) 可屏蔽中断

这类中断可进行屏蔽控制。通过设置优先级指定标志寄存器(PR0L, PR0H, PR1L, PR1H)将可屏蔽中断分为高优先级中断组和低优先级中断组。

支持中断嵌套,即在低优先级的中断服务子程序中可以响应高优先级的中断请求。如果同时产生两个或两个以上具有相同优先级的中断请求,则根据向量中断服务的优先级进行处理。优先级顺序,请参见表 20-1。

产生一个退出待机信号,并退出 STOP 和 HALT 模式。

可屏蔽中断包括外部中断请求和内部中断请求。

外部: 9, 内部: 20

# (2) 软件中断

这是通过执行 BRK 指令产生的一类向量中断。即使禁止中断时也可以响应这类中断。软件中断不受中断优先级控制。

# 20.2 中断源及配置

78K0/KF2 共有 30 种中断源,包括可屏蔽的中断和软件中断。另外,还具有 4 种复位源。(参见表 20-1)。

# 表 20-1. 中断源列表(1/2)

| 中断类型 | 默认                |                     | 中断源                                                         | 内部/ | 向量表   | 基本配置              |
|------|-------------------|---------------------|-------------------------------------------------------------|-----|-------|-------------------|
|      | 优先级 <sup>推1</sup> | 名称                  | 触发器                                                         | 外部  | 地址    | 类型 <sup>推 2</sup> |
| 可屏蔽的 | 0                 | INTLVI              | 低压检测 <sup>性3</sup>                                          | 内部  | 0004H | (A)               |
|      | 1                 | INTP0               | 引脚输入脉冲沿检测                                                   | 外部  | 0006H | (B)               |
|      | 2                 | INTP1               | 1                                                           |     | 0008H |                   |
|      | 3                 | INTP2               | ]                                                           |     | 000AH |                   |
|      | 4                 | INTP3               | ]                                                           |     | 000CH |                   |
|      | 5                 | INTP4               |                                                             |     | 000EH |                   |
|      | 6                 | INTP5               |                                                             |     | 0010H |                   |
|      | 7                 | INTSRE6             | UART6 产生接收错误                                                | 内部  | 0012H | (A)               |
|      | 8                 | INTSR6              | UART6 接收结束                                                  |     | 0014H |                   |
|      | 9                 | INTST6              | UART6 发送结束                                                  |     | 0016H |                   |
|      | 10                | INTCSI10/<br>INTST0 | CSI10 通信结束/ UARTO 通信结束                                      |     | 0018H |                   |
|      | 11                | INTTMH1             | TMH1 与 CMP01 匹配<br>(指定比较寄存器)                                |     | 001AH |                   |
|      | 12                | INTTMH0             | TMH0 与 CMP00 匹配<br>(指定比较寄存器)                                |     | 001CH |                   |
|      | 13                | INTTM50             | TM50 与 CR50 匹配<br>(指定比较寄存器)                                 |     | 001EH |                   |
|      | 14                | INTTM000            | TM00 与 CR000 匹配<br>(指定比较寄存器),<br>TI010 引脚有效沿检测<br>(指定捕捉寄存器) |     | 0020H |                   |
|      | 15                | INTTM010            | TM00 与 CR010 匹配<br>(指定比较寄存器),<br>TI000 引脚有效沿检测<br>(指定捕捉寄存器) |     | 0022H |                   |
|      | 16                | INTAD               | A/D 转换结束                                                    |     | 0024H |                   |
|      | 17                | INTSR0              | UARTO 接收结束或产生接收错误                                           |     | 0026H |                   |
|      | 18                | INTWTI              | 钟表定时器参考时间间隔信号                                               |     | 0028H |                   |
|      | 19                | INTTM51             | TM51 与 CR51 匹配<br>(指定比较寄存器)                                 |     | 002AH |                   |
|      | 20                | INTKR               | 按键中断检测                                                      | 外部  | 002CH | (C)               |
|      | 21                | INTWT               | 钟表定时器溢出                                                     | 内部  | 002EH | (A)               |
|      | 22                | INTP6               | 引脚输入脉冲沿检测                                                   | 外部  | 0030H | (B)               |
|      | 23                | INTP7               | ]                                                           |     | 0032H |                   |

- **注:** 1. 当两个或两个以上可屏蔽中断同时产生时,采用默认的优先级来决定向量中断的处理顺序。优先级 0 的 优先级别最高,而优先级 28 的优先级别最低。
  - 2. 基本配置类型(A)~(D)与图 20-1中(A)~(D)相对应。
  - 3. 当低电压检测寄存器(LVIM)的第 1 位(LVIMD)被清零时。

表 20-1. 中断源列表 (2/2)

| 中断类型 | 默认                |                    | 中断源                                                         | 内部  | 向量表   | 基本匹配              |
|------|-------------------|--------------------|-------------------------------------------------------------|-----|-------|-------------------|
|      | 优先级 <sup>±1</sup> | 名称                 | 触发器                                                         | /外部 | 地址    | 类型 <sup>在 2</sup> |
| 可屏蔽的 | 24                | INTIICO/<br>INTDMU | IIC0 通信结束/乘法/除法操作结束                                         | 内部  | 0034H | (A)               |
|      | 25                | INTCSI11           | CSI11 通信结束                                                  |     | 0036H |                   |
|      | 26                | INTTM001           | TM01 与 CR001 匹配<br>(指定比较寄存器),<br>TI011 引脚有效沿检测<br>(指定捕捉寄存器) |     | 0038H |                   |
|      | 27                | INTTM011           | TM01 与 CR011 匹配<br>(指定比较寄存器),<br>TI001 引脚有效沿检测<br>(指定捕捉寄存器) |     | 003AH |                   |
|      | 28                | INTACSI            | CSIA0 通信结束                                                  |     | 003CH |                   |
| 软件   | -                 | BRK                | 执行 BRK 指令                                                   | -   | 003EH | (D)               |
| 复位   | -                 | RESET              | 复位输入                                                        | -   | 0000H | -                 |
|      |                   | POC                | 上电清零                                                        |     |       |                   |
|      |                   | LVI                | 低压检测 <sup>性3</sup>                                          |     |       |                   |
|      |                   | WDT                | WDT 溢出                                                      |     |       |                   |

- **注:** 1. 当两个或两个以上可屏蔽中断同时产生时采用处理向量中断的默认优先级。优先级 0 的优先级别最高, 而优先级 28 的优先级别最低。
  - 2. 基本配置类型(A)~(D)与图 20-1 中(A)~(D)相对应。
  - 3. 当低电压检测寄存器(LVIM)的第 1 位(LVIMD)设置为 1 时。

图 20-1. 中断功能的基本配置(1/2)

# (A) 内部可屏蔽中断



# (B) 外部可屏蔽中断(INTP0~INTP7)



 IF:
 中断请求标志

 IE:
 中断允许标志

 ISP:
 服务优先级标志

 MK:
 中断屏蔽标志

 PR:
 优先级指定标志

图 20-1. 中断功能的基本配置(2/2)

# (C) 外部可屏蔽中断(INTKR)



# (D) 软件中断



 IF:
 中断请求标志

 IE:
 中断允许标志

 ISP:
 服务优先级标志

 MK:
 中断屏蔽标志

 PR:
 优先级指定标志

 KRM:
 按键返回模式寄存器

# 20.3 控制中断功能的寄存器

以下6种寄存器用于控制中断功能。

- 中断请求标志寄存器(IF0L、IF0H、IF1L、IF1H)
- 中断屏蔽标志寄存器(MK0L、MK0H、MK1L、MK1H)
- 优先级指定标志寄存器(PR0L、PR0H、PR1L、PR1H)
- 外部中断上升沿使能寄存器(EGP)
- 外部中断下降沿使能寄存器(EGN)
- 程序状态字(PSW)

表 20-2 列出了与中断请求源相对应的中断请求标志、中断屏蔽标志和优先级指定标志。

表 20-2. 与中断请求源相对应的标志

| 中断源      |         | 中断请求标志  | 衣 20-2. | 中断屏蔽标志  |         |      | 优       | 先级指定标志  | ř.   |
|----------|---------|---------|---------|---------|---------|------|---------|---------|------|
|          |         |         | 寄存器     |         |         | 寄存器  |         |         | 寄存器  |
| INTLVI   | LVIIF   |         | IF0L    | LVIMK   |         | MK0L | LVIPR   |         | PR0L |
| INTP0    | PIF0    |         |         | PMK0    |         |      | PPR0    |         |      |
| INTP1    | PIF1    |         |         | PMK1    |         |      | PPR1    |         |      |
| INTP2    | PIF2    |         |         | PMK2    |         |      | PPR2    |         |      |
| INTP3    | PIF3    |         |         | РМК3    |         |      | PPR3    |         |      |
| INTP4    | PIF4    |         |         | PMK4    |         |      | PPR4    |         |      |
| INTP5    | PIF5    |         |         | PMK5    |         |      | PPR5    |         |      |
| INTSRE6  | SREIF6  |         |         | SREMK6  |         |      | SREPR6  |         |      |
| INTSR6   | SRIF6   |         | IF0H    | SRMK6   |         | MK0H | SRPR6   |         | PR0H |
| INTST6   | STIF6   |         |         | STMK6   |         |      | STPR6   |         |      |
| INTCSI10 | CSIIF10 | DUALIF0 |         | CSIMK10 | DUALMK0 |      | CSIPR10 | DUALPR0 |      |
| INTST0   | STIF0   | 注 1     |         | STMK0   | 注 2     |      | STPR0   | 注 2     |      |
| INTTMH1  | TMIFH1  |         |         | TMMKH1  |         |      | TMPRH1  |         |      |
| INTTMH0  | TMIFH0  |         |         | TMMKH0  |         |      | TMPRH0  |         |      |
| INTTM50  | TMIF50  |         |         | TMMK50  |         |      | TMPR50  |         |      |
| INTTM000 | TMIF000 |         |         | TMMK000 |         |      | TMPR000 |         |      |
| INTTM010 | TMIF010 |         |         | TMMK010 |         |      | TMPR010 |         |      |
| INTAD    | ADIF    |         | IF1L    | ADMK    |         | MK1L | ADPR    |         | PR1L |
| INTSR0   | SRIF0   |         |         | SRMK0   |         |      | SRPR0   |         |      |
| INTWTI   | WTIIF   |         |         | WTIMK   |         |      | WTIPR   |         |      |
| INTTM51  | TMIF51  |         |         | TMMK51  |         |      | TMPR51  |         |      |
| INTKR    | KRIF    |         |         | KRMK    |         |      | KRPR    |         |      |
| INTWT    | WTIF    |         |         | WTMK    |         |      | WTPR    |         |      |
| INTP6    | PIF6    |         |         | PMK6    |         |      | PPR6    |         |      |
| INTP7    | PIF7    |         |         | PMK7    |         |      | PPR7    |         |      |
| INTIIC0  | IICIF0  |         | IF1H    | IICMK0  |         | MK1H | IICPR0  |         | PR1H |
| INTDMU   | DMUIF   |         |         | DMUMK   |         |      | DMUPR   |         |      |
| INTCSI11 | CSIIF11 |         |         | CSIMK11 |         |      | CSIPR11 |         |      |
| INTTM001 | TMIF001 |         |         | TMMK001 |         |      | TMPR001 |         |      |
| INTTM011 | TMIF011 |         |         | TMMK011 |         |      | TMPR011 |         |      |
| INTACSI  | ACSIIF  |         |         | ACSIMK  | -       |      | ACSIPR  |         |      |

注: 1. 如果产生中断源 INTCSI10 或 INTST0 中的任意一种,则将这些标志位设置为(1)。

2. 支持中断源 INTCSI10 与 INTST0。

# (1) 中断请求标志寄存器(IF0L, IF0H, IF1L, IF1H)

当产生相关的中断请求或执行指令时,这些中断请求标志被置 1。当执行的指令是响应中断请求或复位输入时,这些标志被清零。

当响应中断时,中断请求标志自动清零,然后进入中断例程。

可由 1 位或 8 位存储器操作指令设置 IFOL、IF0H、IF1L 和 IF1H。当 IF0L 与 IF0H、IF1L 与 IF1H 组合起来形成 16 位寄存器 IF0 和 IF1 时,可用 16 位存储器操作指令设置这些寄存器。

复位信号的输入将这些寄存器清零(00H)。

图 20-2. 中断请求标志寄存器(IF0L, IF0H, IF1L, IF1H) 的格式

| 地址:  | FFE0H | 复位后: C       | 00H R/W |                |        |         |                                       |         |        |
|------|-------|--------------|---------|----------------|--------|---------|---------------------------------------|---------|--------|
| 符号   |       | <7>          | <6>     | <5>            | <4>    | <3>     | <2>                                   | <1>     | <0>    |
| IF0L |       | SREIF6       | PIF5    | PIF4           | PIF3   | PIF2    | PIF1                                  | PIF0    | LVIIF  |
|      | _     |              |         |                |        |         |                                       |         |        |
| 地址:  | FFE1F | <b>复</b> 位后: | 00H R/W |                |        |         |                                       |         |        |
| 符号   |       | <7>          | <6>     | <5>            | <4>    | <3>     | <2>                                   | <1>     | <0>    |
| IF0H |       | TMIF010      | TMIF000 | TMIF50         | TMIFH0 | TMIFH1  | DUALIF0                               | STIF6   | SRIF6  |
|      |       |              |         |                |        |         | CSIIF10                               |         |        |
|      | L     |              |         |                |        |         | STIF0                                 |         |        |
|      |       |              |         |                |        |         |                                       |         |        |
| 地址:  | FFE2H | · 复位后:       | 00H R/W |                |        |         |                                       |         |        |
| 符号   | -     | <7>          | <6>     | <5>            | <4>    | <3>     | <2>                                   | <1>     | <0>    |
| IF1L |       | PIF7         | PIF6    | WTIF           | KRIF   | TMIF51  | WTIIF                                 | SRIF0   | ADIF   |
|      |       |              |         |                |        |         |                                       |         |        |
| 地址:  | FFE3F | · 复位后:       | 00H R/W |                |        |         |                                       |         |        |
| 符号   | _     | 7            | 6       | 5              | <4>    | <3>     | <2>                                   | <1>     | <0>    |
| IF1H |       | 0            | 0       | 0              | ACSIIF | TMIF011 | TMIF001                               | CSIIF11 | IICIF0 |
|      |       |              |         |                |        |         |                                       |         | DMUIF  |
|      | _     |              |         |                |        |         |                                       |         |        |
|      |       | XXIFX        |         |                |        | 中断请求标志  | · · · · · · · · · · · · · · · · · · · |         |        |
|      |       | 0            | 没有产生中断  | 所请求信号          |        |         |                                       |         |        |
|      |       | 1            | 产生中断请求  | <b></b> 、中断请求壮 | 犬态     |         |                                       |         |        |
|      | -     |              |         |                |        |         |                                       |         |        |

#### 注意事项: 1. 必须对 IF1H 的第5~7 位清零。

2. 当退出待机模式要使用定时器、串行接口或 A/D 转换器时,在将中断请求标志清零后对这些部件操作一次。噪音可能会干扰中断请求标志。

3. 修改中断请求标志寄存器中的标志时,使用一位存储器操作指令 (CLR1)。当用 C 语言描述时,由于编译后的汇编指令必须是一位存储器操作指令(CLR1),所以应该使用一条一位操作指令,如"IF0L.0 = 0;"和 "\_asm("clr1 IF0L, 0");"。

如果一条 8 位存储器操作指令如"IFOL &= Oxfe;",用 C 语言描述,则编译后将被转换为三条汇编指令:

mov a, IF0L and a, #0FEH mov IF0L, a

在这个例子中,当处于"mov a, IF0L"和 "mov IF0L, a"之间的时序时,即使同一中断请求标志寄存器 (IF0L)的另一位请求标志被设置为 1,则该请求标志将被"mov IF0L, a"清零。因此在 C 语言中使用 8 位存储器操作指令时必须小心。

# (2) 中断屏蔽标志寄存器 (MK0L, MK0H, MK1L, MK1H)

这些中断屏蔽标志用于允许/禁止相关的可屏蔽中断服务。

可由 1 位或 8 位存储器操作指令设置 MKOL、 MKOH、MK1L 和 MK1H。 当 MKOL 与 MK0H、MK1L 与 MK1H组合起来形成 16 位寄存器 MKO 与 MK1 时,可由 16 位存储器操作指令设置这些寄存器。复位信号的输入将这些寄存器的内容设置为 FFH。

图 20-3. 中断屏蔽标志寄存器(MK0L, MK0H, MK1L, MK1H) 的格式

| 付号                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 地址:               | FFE4H   | · 复位后:                   | FFH R/W             |          |                       |                     |                   |       |                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------|--------------------------|---------------------|----------|-----------------------|---------------------|-------------------|-------|-----------------|
| 地址: FFE5H 复位后: FFH R/W 符号                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 符号                |         | <7>                      | <6>                 | <5>      | <4>                   | <3>                 | <2>               | <1>   | <0>             |
| 符号         <7> <6> <5> <4> <3> <2> <1> <0>           MK0H         TMMK010         TMMK000         TMMK50         TMMKH0         TMMKH1         DUALMK0 CSIMK0 STMK6         SRMK6           地址:         FFE6H         复位后:         FFH R/W         FFE6H         名> <5> <4> <3> <2> <1> <0>         <0>           MK1L         PMK7         PMK6         WTMK         KRMK         TMMK51         WTIMK         SRMK0         ADMK           地址:         FFE7H         复位后:         FFH R/W         FFE7H         复位后:         FFH R/W           符号         7         6         5         <4> <3> <2> <1> <0>         <0>           MK1H         1         1         1         ACSIMK         TMMK011         TMMK001         CSIMK11         IICMK0 DMUMK           XXMKX         中断服务控制         0         允许中断服务         中断服务控制 | MK0L              |         | SREMK6                   | PMK5                | PMK4     | PMK3                  | PMK2                | PMK1              | PMK0  | LVIMK           |
| 符号       <7> <6> <5> <4> <3> <2> <1> <0>         MK0H       TMMK010       TMMK000       TMMK50       TMMKH0       TMMKH1       DUALMK0 CSIMK0 STMK6       SRMK6         地址:       FFE6H       复位后:       FFH R/W       FFE6H       名> <5> <4> <3> <2> <1> <0>       <0>         MK1L       PMK7       PMK6       WTMK       KRMK       TMMK51       WTIMK       SRMK0       ADMK         地址:       FFE7H       复位后:       FFH R/W       FFE7H       复位后:       FFH R/W        <0>       <0>       <0>         MK1H       1       1       1       ACSIMK       TMMK011       TMMK001       CSIMK11       IICMK0 DMUMK         XXMKX       中断服务控制       0       允许中断服务       中断服务控制                                                                                                                                                 |                   |         |                          |                     |          |                       |                     |                   |       |                 |
| MK0H         TMMK010         TMMK000         TMMK50         TMMKH0         TMMKH1         DUALMK0 CSIMK0 STMK6         SRMK6           地址:         FFE6H         复位后:         FFH R/W         ************************************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 地址:               | FFE5H   | <b>复</b> 位后:             | FFH R/W             |          |                       |                     |                   |       |                 |
| 地址: FFE6H   复位后: FFH   R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 符号                | _       | <7>                      | <6>                 | <5>      | <4>                   | <3>                 | <2>               | <1>   | <0>             |
| 地址: FFE6H 复位后: FFH R/W       符号     <7> <6> <5> <4> <3> <2> <1> <0>       MK1L     PMK7     PMK6     WTMK     KRMK     TMMK51     WTIMK     SRMK0     ADMK       地址: FFE7H     复位后: FFH R/W       符号     7 6 5     5 <4> <3> <2> <1> <0>     <0>       MK1H     1 1 1 1 ACSIMK     TMMK011     TMMK001     CSIMK11     IICMK0 DMUMK       XXMKX     中断服务控制       0 允许中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                         | MK0H              |         | TMMK010                  | TMMK000             | TMMK50   | TMMKH0                | TMMKH1              | DUALMK0           | STMK6 | SRMK6           |
| 地址: FFE6H 复位后: FFH R/W<br>符号 <7> <6> <5> <4> <3> <2> <1> <0><br>MK1L PMK7 PMK6 WTMK KRMK TMMK51 WTIMK SRMK0 ADMK<br>地址: FFE7H 复位后: FFH R/W<br>符号 7 6 5 <4> <3> <2> <1> <0><br>MK1H 1 1 1 ACSIMK TMMK011 TMMK001 CSIMK11 IICMK0 DMUMK<br>中断服务控制                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   |         |                          |                     |          |                       |                     |                   |       |                 |
| 符号                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   | L       |                          |                     |          |                       |                     | STIVIKU           |       |                 |
| 符号                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Hh H              | EEE6L   | <b>4</b>                 | FEH D/M             |          |                       |                     |                   |       |                 |
| MK1L         PMK7         PMK6         WTMK         KRMK         TMMK51         WTIMK         SRMK0         ADMK           地址:         FFE7H         复位后:         FFH         R/W           符号         7         6         5         <4>         <3>         <2>         <1>         <0>           MK1H         1         1         1         ACSIMK         TMMK011         TMMK001         CSIMK11         IICMK0 DMUMK           XXMKX         中断服务控制           0         允许中断服务                                                                                                                                                                                                                                                                                                                                               | MOME:             | I I LOI | 2 处型川;                   | 1111 17/11          |          |                       |                     |                   |       |                 |
| 地址: FFE7H 复位后: FFH R/W       符号     7     6     5     <4> <3> <2> <1> <0>       MK1H     1     1     1     ACSIMK TMMK011 TMMK001 CSIMK11 IICMK0 DMUMK       XXMKX       0     允许中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <b>2</b> 2. 卫.    |         | .7.                      | .0.                 | .E.      | .4.                   | .0.                 | -0-               | .4.   | ٠0٠             |
| 符号         7         6         5         <4>         <3>         <2>         <1>         <0>           MK1H         1         1         1         ACSIMK         TMMK011         TMMK001         CSIMK11         IICMK0 DMUMK           XXMKX         中断服务控制           0         允许中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   | Γ       |                          | 1                   |          | 1                     | 1                   | 1                 |       | _               |
| 符号         7         6         5         <4>         <3>         <2>         <1>         <0>           MK1H         1         1         1         ACSIMK         TMMK011         TMMK001         CSIMK11         IICMK0 DMUMK           XXMKX         中断服务控制           0         允许中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   |         |                          | 1                   |          | 1                     | 1                   | 1                 |       | _               |
| MK1H         1         1         ACSIMK         TMMK011         TMMK001         CSIMK11         IICMK0 DMUMK           XXMKX         中断服务控制           0         允许中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | MK1L              |         | PMK7                     | PMK6                |          | 1                     | 1                   | 1                 |       | _               |
| XXMKX   中断服务控制     0   允许中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | MK1L              | FFE7H   | PMK7                     | PMK6                |          | 1                     | 1                   | 1                 |       | _               |
| XXMKX         中断服务控制           0         允许中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | MK1L<br>地址:       | FFE7H   | PMK7<br>H 复位后:           | PMK6                | WTMK     | KRMK                  | TMMK51              | WTIMK             | SRMK0 | ADMK            |
| 0 允许中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MK1L<br>地址:<br>符号 | FFE7H   | PMK7<br>H 复位后:<br>7      | PMK6  FFH R/W 6     | WTMK     | KRMK                  | TMMK51 <3>          | WTIMK <2>         | SRMK0 | ADMK            |
| 0 允许中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MK1L<br>地址:<br>符号 | FFE7H   | PMK7<br>H 复位后:<br>7      | PMK6  FFH R/W 6     | WTMK     | KRMK                  | TMMK51 <3>          | WTIMK <2>         | SRMK0 | ADMK <0> IICMK0 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | MK1L<br>地址:<br>符号 | FFE7h   | PMK7<br>H 复位后:<br>7      | PMK6  FFH R/W 6     | WTMK     | KRMK                  | TMMK51 <3>          | WTIMK <2>         | SRMK0 | ADMK <0> IICMK0 |
| , +- 1 -1 MC III 67                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | MK1L<br>地址:<br>符号 | FFE7H   | PMK7<br>引 复位后:<br>7<br>1 | PMK6  FFH R/W 6     | WTMK     | KRMK<br><4><br>ACSIMK | TMMK51  <3> TMMK011 | WTIMK <2> TMMK001 | SRMK0 | ADMK <0> IICMK0 |
| 1 禁止中断服务                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MK1L<br>地址:<br>符号 | FFE7H   | PMK7<br>引 复位后:<br>7<br>1 | PMK6  FFH R/W  6  1 | WTMK 5 1 | KRMK<br><4><br>ACSIMK | TMMK51  <3> TMMK011 | WTIMK <2> TMMK001 | SRMK0 | ADMK <0> IICMK0 |

注意事项: MK1H 的第 5~ 7 位必须为 1。

# (3) 优先级指定标志寄存器(PR0L, PR0H, PR1L, PR1H)

这些优先级指定标志寄存器用于设置相关的可屏蔽中断优先级次序。

可由 1 位或 8 位存储器操作指令设置 PR0L、 PR0H、 PR1L 和 PR1H 。当 PR0L 与 PR0H、PR1L 与 PR1H 组合起来形成 16 位寄存器 PR0 与 PR1 时,可由 16 位存储器操作指令设置这些寄存器。复位信号的输入将这些寄存器内容设置为 FFH。

图 20-4. 优先级指定标志寄存器(PR0L, PR0H, PR1L, PR1H) 的格式

| 地址: FFE8       | H 复位后:       | FFH R/W |        |             |                |         |       |       |
|----------------|--------------|---------|--------|-------------|----------------|---------|-------|-------|
| Symbol         | <7>          | <6>     | <5>    | <4>         | <3>            | <2>     | <1>   | <0>   |
| PR0L           | SREPR6       | PPR5    | PPR4   | PPR3        | PPR2           | PPR1    | PPR0  | LVIPR |
|                |              |         |        |             |                |         |       |       |
| 地址: FFE9       | H 复位后:       | FFH R/W |        |             |                |         |       |       |
| 符号             | <7>          | <6>     | <5>    | <4>         | <3>            | <2>     | <1>   | <0>   |
| PR0H           | TMPR010      | TMPR000 | TMPR50 | TMPRH0      | TMPRH1         | DUALPR0 | STPR6 | SRPR6 |
|                |              |         |        |             |                | CSIPR10 |       |       |
|                |              |         |        |             |                | STPR0   |       |       |
|                |              |         |        |             |                |         |       |       |
| 地址: FFEA       | H 复位后:       | FFH R/W |        |             |                |         |       |       |
| 符号             | <7>          | <6>     | <5>    | <4>         | <3>            | <2>     | <1>   | <0>   |
| PR1L           | PPR7         | PPR6    |        |             |                |         |       |       |
|                |              | FFRO    | WTPR   | KRPR        | TMPR51         | WTIPR   | SRPR0 | ADPR  |
|                |              | FFRO    | WIPR   | KRPR        | TMPR51         | WTIPR   | SRPR0 | ADPR  |
| 地址: FFEB       | BH 复位后:      | FFH R/W |        | KRPR        | TMPR51         | WTIPR   | SRPR0 | ADPR  |
| 地址: FFEB<br>符号 | BH 复位后:<br>7 |         |        | KRPR<br><4> | TMPR51 <3>     | WTIPR   | SRPR0 | ADPR  |
|                | 3-2,,        | FFH R/W | ,      |             |                |         |       |       |
| 符号             | 7            | FFH R/W | 5      | <4>         | <3>            | <2>     | <1>   | <0>   |
| 符号             | 7            | FFH R/W | 5      | <4>         | <3>            | <2>     | <1>   | <0>   |
| 符号             | 7            | FFH R/W | 5      | <4>         | <3>            | <2>     | <1>   | <0>   |
| 符号             | 7            | FFH R/W | 5      | <4>         | <3><br>TMPR011 | <2>     | <1>   | <0>   |

注意事项: PR1H 的第5~7位 必须为1.

# (4) 外部中断上升沿使能寄存器(EGP) 、 外部中断下降沿使能寄存器(EGN)

这两个寄存器用于指定 INTP0 ~INTP7 的有效沿。 可由 1 位或 8 位存储器操作指令设置 EGP 和 EGN。 复位信号的输入将这些寄存器清零 (00H)。

# 图 20-5. 外部中断上升沿使能寄存器(EGP) 和外部中断下降沿使能寄存器(EGN) 的格式

地址: FF48H 复位后: 00H R/W 符号 7 6 5 4 3 2 0 EGP EGP7 EGP6 EGP5 EGP4 EGP3 EGP2 EGP1 EGP0 地址: FF49H 复位后: 00H R/W 符号 7 2 6 5 4 3 0

| EGN7 EGN6 EGN5 EGN4 EGN3 EGN2 EGN1 EG | N0 |
|---------------------------------------|----|

| EGPn | EGNn | INTPn 引脚有效沿的选择 (n = 0~ 7) |
|------|------|---------------------------|
| 0    | 0    | 禁止脉冲沿检测                   |
| 0    | 1    | 下降沿                       |
| 1    | 0    | 上升沿                       |
| 1    | 1    | 兼有上升沿和下降沿                 |

表 20-3 显示了与 EGPn 和 EGNn 相关的端口。

表 20-3. 与 EGPn 和 EGNn 相关的端口

| 检测使能 | <b></b> | 脉冲沿检测端口 | 外部请求信号 |
|------|---------|---------|--------|
| EGP0 | EGN0    | P120    | INTP0  |
| EGP1 | EGN1    | P30     | INTP1  |
| EGP2 | EGN2    | P31     | INTP2  |
| EGP3 | EGN3    | P32     | INTP3  |
| EGP4 | EGN4    | P33     | INTP4  |
| EGP5 | EGN5    | P16     | INTP5  |
| EGP6 | EGN6    | P140    | INTP6  |
| EGP7 | EGN7    | P141    | INTP7  |

注意事项:在从外部中断功能切换到端口功能时可能会检测到脉冲沿,因此通过将 EGPn 和 EGNn 清零可选择端口模式。

备注: n=0~7

EGN

# (5) 程序状态字(PSW)

PSW 用于保存指令执行结果和中断请求的当前状态。在 PSW 中包含 IE 标志(设置允许/禁止可屏蔽中断)和 ISP 标志(控制中断嵌套)。

除了 8 位读/写操作指令,还可使用位操作指令和专用指令(EI 和 DI)对该寄存器进行操作。在响应向量中断请求时,如果执行 BRK 指令,则将 PSW 的内容自动保存到堆栈中,并且将 IE 标志复位为 0。如果响应可屏蔽中断请求,则将被响应中断的优先级指定标志的内容转移到 ISP 标志中。执行 PUSH PSW 指令将 PSW 的内容保存到堆栈中。而执行 RETI、RETB 和 POP PSW 指令可将这些内容从堆栈中恢复。复位信号的输入将 PSW 设置为 02H。

图 20-6. 程序状态字的格式



# 20.4 中断服务操作

#### 20.4.1 可屏蔽的中断响应

当中断请求标志=1 且与该中断请求相关的屏蔽标志(MK)被清零时,可以响应这个可屏蔽中断请求。如果处于中断允许状态(IE=1),可以响应向量中断请求。但在一个较高优先级中断请求服务期间(ISP标志复位为 0),不响应低优先级的中断请求。

从一个可屏蔽中断请求产生到中断服务执行所经历的时间如表 20-4 所示。

中断请求响应时序可参见图 20-8 和 20-9.

表 20-4. 从可屏蔽中断产生到执行中断服务所需要的时间

|           | 最短时间 | 最长时间 <sup>推</sup> |
|-----------|------|-------------------|
| ≝××PR = 0 | 7个时钟 | 32 个时钟            |
| 当××PR = 1 | 8个时钟 | 33 个时钟            |

注 如果是在除法指令执行之前产生一个中断请求,则等待时间会更长。

# **备注:** 1个时钟: 1/fcpu (fcpu: CPU 时钟)

如果同时产生两个或两个以上的可屏蔽中断请求,则首先响应优先级指定标志中优先级别高的请求。如果两个或两个以上的中断请求具有相同的优先级别,则首先响应具有最高默认优先级的中断请求。

当允许响应中断请求时,处于等待状态的中断请求被响应。

图 20-7 显示了中断请求响应算法。

如果响应了一个可屏蔽中断请求,则将 PSW、PC 的内容依次保存到堆栈中,然后将 IE 标志复位为 0,并将与被响应的中断相关的优先级指定标志的内容传送到 ISP 中。将用于中断请求的向量表数据传送到 PC 中,并转移。

可通过执行 RETI 指令从中断返回。

图 20-7. 中断请求响应处理



x×IF: 中断请求标志x×MK: 中断屏蔽标志x×PR: 优先级指定标志

IE: 控制可屏蔽中断请求响应的标志 (1 = 允许、0 = 禁止)

**ISP**: 指示正在服务的中断优先级别的标志 (0 =高优先级的中断服务,1 =没有中断请求被响应,或低优先级的中断服务)

图 20-8. 中断请求响应时序(最短时间)



**备注:** 1个时钟: 1/fcpu (fcpu: CPU 时钟)

图 20-9. 中断请求响应时序(最长时间)



**备注:** 1个时钟: 1/fcpu (fcpu: CPU 时钟)

#### 20.4.2 软件中断请求响应

执行 BRK 指令可响应软件中断。软件中断不能被禁止。

如果响应了一个软件中断请求,则将程序状态字(PSW)和程序计数器(PC)的内容依次保存到堆栈中,然后将 IE 标志复位为 0,并将向量表的内容(003EH、003FH)传送到 PC 中,然后转移。

可通过执行 RETB 指令从软件中断返回。

注意事项: 不能使用 RETI 指令从软件中断返回。

#### 20.4.3 中断嵌套

在执行一个中断服务程序时,又响应了其他中断,这时就产生了中断嵌套。

除非选择允许中断请求响应状态(IE=1),否则不会产生中断嵌套。在响应一个中断请求时,禁止响应其它中断请求(IE=0)。因此,如果要允许中断嵌套,必须在中断服务期间执行 EI 指令,将 IE 标志置 1,从而允许响应其它中断请求。

此外,即使允许中断,也不一定允许中断嵌套,这是因为受到中断优先级控制的限制。可使用两类优先级控制方式:默认优先级控制和可编程优先级控制。可编程优先级控制用于中断嵌套。

在中断允许状态中,如果产生的中断请求的优先级与正在服务的中断优先级相等或高于它,则响应该中断请求,从而产生中断嵌套。如果产生的中断请求的优先级低于正在服务的中断优先级,则不响应该中断请求。由于禁止中断或中断请求的优先级别较低,这些不被允许的中断请求处于等待状态。若当前的中断服务已结束,则在执行至少一条主程序指令后才可响应处于等待状态的中断请求。

表 20-5 显示了允许中断嵌套的中断请求之间的关系,图 20-10 为中断嵌套示例。

中断嵌套 可屏蔽中断请求 软件中断请求 PR = 0PR = 1正在服务的中断 IE = 1 IE = 0IE = 1 IE = 0可屏蔽的中断 ISP = 00 0 ISP = 10 0 0 软件中断 0 0 0 × ×

表 20-5. 中断服务期间允许进行中断嵌套的中断请求之间的关系

**备注:** 1. O: 允许中断嵌套

2. x: 禁止中断嵌套

3. ISP和IE为PSW中的标志位。

ISP = 0: 正在服务一个高优先级中断。

ISP = 1: 无中断请求被响应,或正在服务一个低优先级中断。

IE = 0: 禁止响应中断请求。

IE = 1: 允许响应中断请求。

4. PR 为 PROL、PROH、PR1L 和 PR1H 中的标志位。

PR = 0: 高优先级

PR = 1: 低优先级

# 图 20-10. 中断嵌套示例(1/2)

例 1. 产生两次中断嵌套



在进行 INTxx 中断服务期间,响应了两个中断请求 INTyy 和 INTzz,这时就产生了中断嵌套。在响应每个中断之前,必须先执行 EI 指令才能允许响应中断请求。

# 例 2. 由于优先级控制没有产生中断嵌套



在 INTxx 中断服务期间不响应中断请求 INTyy,因为 INTyy 的优先级低于 INTxx,这样就不会产生中断嵌套。中断请求 INTyy 处于等待状态,在执行一条主程序指令后响应该中断请求。

PR = 0: 高优先级

PR = 1: 低优先级

IE = 0: 禁止响应中断请求

# 图 20-10. 中断嵌套示例(2/2)

# 例 3. 由于不允许中断没有产生中断嵌套



在 INTxx 中断服务期间不允许中断(不执行 EI 指令),因此不响应中断请求 INTyy,这样也不会产生中断嵌套。中断请求 INTyy 处于等待状态,在执行一条主程序指令后响应该中断请求。

PR = 0: 高优先级

IE = 0: 禁止响应中断请求

#### 20.4.4 保持中断请求

在某些指令执行期间,即使出现中断请求,请求响应也要保持等待状态,直到下一条指令执行结束。以下列出这类指令(中断请求保持指令)。

- MOV PSW, #byte
- MOV A, PSW
- MOV PSW, A
- MOV1 PSW. bit, CY
- MOV1 CY, PSW. bit
- AND1 CY, PSW. bit
- OR1 CY, PSW. bit
- XOR1 CY, PSW. bit
- SET1 PSW. bit
- CLR1 PSW. bit
- RETB
- RETI
- PUSH PSW
- POP PSW
- BT PSW. bit, \$addr16
- BF PSW. bit, \$addr16
- BTCLR PSW. bit, \$addr16
- EI
- DI
- 用于 IF0L、IF0H、 IF1L、 IF1H、 MK0L、 MK0H、 MK1L、 MK1H、 PR0L、PR0H、 PR1L 和 PR1H 寄存器 的操作指令。

注意事项: BRK 指令不属于上述列出的中断请求保持指令。但通过执行 BRK 指令激活的软件中断会将 IE 标志清零。因此,即使在执行 BRK 指令期间产生可屏蔽中断请求,该中断请求也不会被响应。

图 20-11 显示了处于等待状态的中断请求时序。

图 20-11. 中断请求保持时序



备注:

- 1. 指令 N: 中断请求保持指令
- 2. 指令 M: 除中断请求保持指令之外的指令
- 3. ××PR (优先级别)的值不会影响××IF (中断请求)的操作。

# 第二十一章 按键中断功能

# 21.1 按键中断功能

可通过设置按键返回模式寄存器(KRM)和向按键中断输入引脚(KR0~KR7)输入一个下降沿产生按键中断 (INTKR)。

表 21-1. 按键中断检测引脚的分配

| 标识   | 描述                 |
|------|--------------------|
| KRM0 | 以 1 位操作模式控制 KR0 信号 |
| KRM1 | 以 1 位操作模式控制 KR1 信号 |
| KRM2 | 以 1 位操作模式控制 KR2 信号 |
| KRM3 | 以 1 位操作模式控制 KR3 信号 |
| KRM4 | 以 1 位操作模式控制 KR4 信号 |
| KRM5 | 以 1 位操作模式控制 KR5 信号 |
| KRM6 | 以 1 位操作模式控制 KR6 信号 |
| KRM7 | 以 1 位操作模式控制 KR7 信号 |

# 21.2 按键中断的配置

按键中断包括以下硬件。

表 21-2 按键中断的配置

| 项目    | 配置             |
|-------|----------------|
| 控制寄存器 | 按键返回模式寄存器(KRM) |

图 21-1 按键中断的框图



# 21.3 控制按键中断的寄存器

# (1) 按键返回模式寄存器(KRM)

该寄存器使用 KR0~KR7 信号分别控制 KRM0 ~ KRM7 位。 KRM 可由 1 位或 8 位存储器操作指令设置。 复位信号的产生将 KRM 清零(00H)。

#### 图 21-2 按键返回模式寄存器 (KRM)的格式

地址: FF6EH 复位后: 00H R/W

| 符号  | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| KRM | KRM7 | KRM6 | KRM5 | KRM4 | KRM3 | KRM2 | KRM1 | KRM0 |

| KRMn | 按键中断模式控制  |
|------|-----------|
| 0    | 不检测按键中断信号 |
| 1    | 检测按键中断信号  |

- 注意事项: 1. 如果 KRM0  $\sim$  KRM7 中任何一位被设置为 1,则将上拉电阻寄存器 7(PU7)的 0 $\sim$ 7 位(PU70  $\sim$  PU77) 的相应位设置为 1。
  - 2. 如果 KRM 发生变化,则中断请求标志可能被设置。因此可以先禁止中断,再修改 KRM。先将中断 请求标志清零,再允许中断。
  - 3. 在按键中断模式中没有被使用的位可用作通用端口。

#### 第二十二章 待机功能

#### 22.1 待机功能及配置

#### 22.1.1 待机功能

待机功能用于减少系统的工作电流,有以下两种模式。

#### (1) HALT 模式

通过执行 HALT 指令设置 HALT 模式。在 HALT 模式中,CPU 操作时钟停止。如果设置 HALT 模式前,高速系统时钟振荡器、内部高速振荡器、内部低速振荡器或子系统时钟振荡器正在使用,则设置后每种时钟的振荡继续。在此模式中,工作电流不如 STOP 模式中下降得多,但 HALT 模式对于中断请求产生后立即重启操作和频繁进行间断的操作非常有效。

#### (2) STOP 模式

通过执行 STOP 指令设置 STOP 模式。在 STOP 模式中,高速系统时钟振荡器和内部高速振荡器停止操作,整个系统的操作停止,这样 CPU 的工作电流将会大幅下降。

可通过中断请求释放该模式,这样,被中断的操作可以继续执行。由于选择 X1 时钟时,在释放 STOP 模式后需要一段等待时间以确保振荡器振荡稳定,因此如果需要在产生中断请求后立即进行处理,则应选择 HALT 模式。

在这两种模式中,寄存器、标志和数据存储器的内容将会保持进入待机模式前的内容。I/O 端口输出锁存器和输出缓冲器的状态也将被保持。

- 注意事项: 1. 仅当 CPU 使用主系统时钟时,才能使用 STOP 模式。不能停止子系统时钟的振荡。而当 CPU 使用主系统时钟或子系统时钟时,均可以使用 HALT 模式。
  - 2. 当切换到 STOP 模式时,在执行 STOP 指令前必须停止使用主系统时钟的外部硬件的操作。
  - 3. 当使用待机功能时,建议采用以下步骤降低 A/D 转换器的操作电流: 首先将 A/D 转换器模式寄存器 (ADM) 的第7位 (ADCS) 和第0位 (ADCE) 清零以停止 A/D 转换操作,然后执行 STOP 指令。

#### 22.1.2 控制待机功能的寄存器

待机功能由以下两个寄存器控制。

- 振荡稳定时间计数器的状态寄存器 (OSTC)
- 振荡稳定时间选择寄存器 (OSTS)

**备注**: 有关这些寄存器启动、停止以及时钟选择的情况,可参见 **第六章 时钟发生器。** 

# (1) 振荡稳定时间计数器的状态寄存器 (OSTC)

这是 X1 时钟振荡稳定时间计数器的状态寄存器。如果 CPU 使用 X1 振荡时钟、内部高速振荡时钟或子系统时钟,则可以检测 X1 时钟振荡稳定时间。

可由1位或8位存储器操作指令读取OSTC。

复位释放(通过 RESET 输入、POC、LVI 和 WDT)、STOP 指令以及 MSTOP (MOC 的第 7 位) = 1 可以将 OSTC 清零(00H)。

图 22-1 振荡稳定时间计数器的状态寄存器 (OSTC) 的格式

 地址: FFA3H
 复位后: 00H
 R

 符号
 7
 6
 5
 4
 3
 2
 1
 0

 OSTC
 0
 0
 MOST11
 MOST13
 MOST14
 MOST15
 MOST16

| MOST11 | MOST13 | MOST14 | MOST15 | MOST16 | 振荡稳定时间的状态                |               | 犬态                    |
|--------|--------|--------|--------|--------|--------------------------|---------------|-----------------------|
|        |        |        |        |        |                          | fx = 10 MHz   | fx = 20 MHz           |
| 1      | 0      | 0      | 0      | 0      | 2 <sup>11</sup> /fx min. | 204.8 μs min. | 102.4 μs min.         |
| 1      | 1      | 0      | 0      | 0      | 2 <sup>13</sup> /fx min. | 819.2 μs min. | 409.6 μs min.         |
| 1      | 1      | 1      | 0      | 0      | 2 <sup>14</sup> /fx min. | 1.64 ms min.  | 819.2 <i>µ</i> s min. |
| 1      | 1      | 1      | 1      | 0      | 2 <sup>15</sup> /fx min. | 3.27 ms min.  | 1.64 ms min.          |
| 1      | 1      | 1      | 1      | 1      | 2 <sup>16</sup> /fx min. | 6.55 ms min.  | 3.27 ms min.          |

注意事项: 1. 在经历上述时间后,从 MOST11 起各位被设置为 1,并保持为 1。

- 2. 振荡稳定时间计数器的计数达到 OSTS 设置的振荡稳定时间。如果已进入 STOP 模式并在 CPU 使用内部高速振荡时钟时释放 STOP 模式,则可以按以下方式设置振荡稳定时间。
  - 预期的 OSTC 振荡稳定时间 ≤ OSTS 设置的振荡稳定时间 因此需要注意,在释放 STOP 模式后,只有通过 OSTS 设置的振荡稳定时间期间的状态 被设置到 OSTC。
- 3. X1 振荡稳定等待时间不包括从释放 STOP 模式到时钟振荡启动这段时间(即下图 "a" 所示的部分)。



**备注:** fx: X1 时钟振荡频率

# (2) 振荡稳定时间选择寄存器(OSTS)

该寄存器用于选择释放 STOP 模式后 X1 时钟振荡稳定等待时间。

在释放 STOP 模式后且 CPU 使用 X1 时钟时,等待由 OSTS 设置的时间。

当释放 STOP 模式后且 CPU 使用内部高速振荡时钟时,可通过使用 OSTC 确认是否已经历了预期的振荡稳定时间。振荡稳定时间可根据 OSTC 设置的时间来检测。

可由8位存储器操作指令设置OSTS。

复位信号的产生将 OSTS 设置为 05H。

图 22-2 振荡稳定时间选择寄存器 (OSTS) 的格式

地址: FFA4H 复位后: 05H R/W 符号 7 6 3 2 1 0 **OSTS** 0 0 0 0 0 OSTS2 OSTS1 OSTS0

| OSTS2 | OSTS1 | OSTS0 | 振荡稳定时间的选择           |                  |                  |
|-------|-------|-------|---------------------|------------------|------------------|
|       |       |       |                     | fx = 10 MHz      | fx = 20 MHz      |
| 0     | 0     | 1     | 2 <sup>11</sup> /fx | 204.8 <i>μ</i> s | 102.4 <i>μ</i> s |
| 0     | 1     | 0     | 2 <sup>13</sup> /fx | 819.2 <i>μ</i> s | 409.6 μs         |
| 0     | 1     | 1     | 2 <sup>14</sup> /fx | 1.64 ms          | 819.2 <i>μ</i> s |
| 1     | 0     | 0     | 2 <sup>15</sup> /fx | 3.27 ms          | 1.64 ms          |
| 1     | 0     | 1     | 2 <sup>16</sup> /fx | 6.55 ms          | 3.27 ms          |
|       | 其它情况  |       | 禁止设置                |                  |                  |

注意事项: 1. 如果在 X1 时钟用作 CPU 时钟时要设置 STOP 模式,则应在执行 STOP 指令之前设置 OSTS。

- 2. 在 X1 时钟振荡稳定期间不要修改 OSTS 寄存器的值。
- 3. 振荡稳定时间计数器的计数达到 OSTS 设置的振荡稳定时间。如果已进入 STOP 模式, 并在 CPU 使用内部高速振荡时钟时释放 STOP 模式,则可以按以下方式设置振荡稳定 时间。
  - 预期的 OSTC 振荡稳定时间 ≤ OSTS 设置的振荡稳定时间 因此需要注意,在释放 STOP 模式后,只有通过 OSTS 设置的振荡稳定时间期间的状态 被设置到 OSTC。
- 4. X1 时钟振荡等待时间不包括从释放 STOP 模式到时钟振荡启动这段时间(即下图 "a" 所示的部分)。



**备注:** fx: X1 时钟振荡频率

# 22.2 待机功能的操作

# 22.2.1 HALT 模式

# (1) HALT 模式

通过执行 HALT 指令设置 HALT 模式。无论设置前 CPU 使用的是高速系统时钟、内部高速振荡时钟还是子系统时钟,都可以设置 HALT 模式。

HALT 模式中的操作状态如下所示。

# 表 22-1 HALT 模式中的操作状态(1/2)

|                            |      |         | 表 22-1 HALT 模式                              | 式中的操作状态(1/2)        |                           |  |  |  |
|----------------------------|------|---------|---------------------------------------------|---------------------|---------------------------|--|--|--|
| HALT 模式设置                  |      |         | 当CP                                         | U 使用主系统时钟并执行 HALT   | 指令时                       |  |  |  |
| 项目                         |      |         | 当 CPU 使用内部高速振荡时钟<br>(f <sub>RH</sub> )时     | 当 CPU 使用 X1 时钟(fx)时 | 当 CPU 使用外部主系统时钟 (fexclx)时 |  |  |  |
| 系统时钟                       |      |         | 停止 CPU 时钟                                   |                     |                           |  |  |  |
| 主系统时钟                      | ı    | frh     | 操作继续 (不能停止) 保持设置 HALT 模式前的状态                |                     |                           |  |  |  |
| 土水丸町町                      |      | fх      | 保持设置 HALT 模式前的状态 操作继续 (不能停止)                |                     | 保持设置 HALT 模式前的状态          |  |  |  |
|                            |      | fexclk  | 由外部时钟输入进行操作或停止                              |                     | 操作继续 (不能停止)               |  |  |  |
| 子系统时钟                      | ı    | fxt     | 保持设置 HALT 模式前的状态                            |                     |                           |  |  |  |
| 1 3/1-3/141 11             |      | fexclks | 由外部时钟输入进行操作或停止                              |                     |                           |  |  |  |
| frL                        |      | TEACING | 保持设置 HALT 模式前的状态                            | •                   |                           |  |  |  |
| CPU                        |      |         | 操作停止                                        |                     |                           |  |  |  |
| Flash 存储器                  |      |         | 操作停止                                        |                     |                           |  |  |  |
| RAM                        |      |         | 保持设置 HALT 模式前的状态                            |                     |                           |  |  |  |
| 端口(锁存器)                    |      |         | 保持设置 HALT 模式前的状态                            |                     |                           |  |  |  |
| 16 位定时器/事                  | 件计数  | 00      | 可操作                                         |                     |                           |  |  |  |
| 器                          |      | 01      |                                             |                     |                           |  |  |  |
| 8位定时器/事件                   | +计数器 | 50      |                                             |                     |                           |  |  |  |
|                            |      | 51      |                                             |                     |                           |  |  |  |
| 8位定时器                      |      | H0      |                                             |                     |                           |  |  |  |
|                            |      | H1      | 1                                           |                     |                           |  |  |  |
| 钟表定时器                      |      | ı       |                                             |                     |                           |  |  |  |
| 看门狗定时器                     |      |         | 可操作。当通过可选字节设置"可以由软件停止内部低速振荡器"时,停止看门狗定时器的时钟。 |                     |                           |  |  |  |
| 时钟输出                       |      |         | 可操作                                         |                     |                           |  |  |  |
| 蜂鸣器输出                      |      |         |                                             |                     |                           |  |  |  |
| A/D 转换器                    |      |         |                                             |                     |                           |  |  |  |
| 串行接口                       | UAF  | RT0     |                                             |                     |                           |  |  |  |
|                            | UAF  | RT6     |                                             |                     |                           |  |  |  |
| CSI<br>CSI<br>CSI,<br>IIC0 |      | 10      |                                             |                     |                           |  |  |  |
|                            |      | 11      |                                             |                     |                           |  |  |  |
|                            |      | A0      |                                             |                     |                           |  |  |  |
|                            |      |         |                                             |                     |                           |  |  |  |
| 乘法器/除法器                    |      |         |                                             |                     |                           |  |  |  |
| 上电清零(POC)功能                |      |         |                                             |                     |                           |  |  |  |
| 低电压检测功能                    |      |         |                                             |                     |                           |  |  |  |
| 外部中断                       |      |         |                                             |                     |                           |  |  |  |

**备注:** 内部高速振荡时钟

fx: X1 时钟

fexclk: 外部主系统时钟

fxT: XT1 时钟

 fexclks:
 外部子系统时钟

 fkl:
 内部低速振荡时钟

\*

# 表 22-1 HALT 模式中的操作状态 (2/2)

|                  |                 |                     | <b>大江</b> IIALI 侯八十的床                           |                   |  |  |  |  |  |
|------------------|-----------------|---------------------|-------------------------------------------------|-------------------|--|--|--|--|--|
| 明ALT 模式设置项目      |                 |                     | 当 CPU 使用于                                       | 子系统时钟并执行 HALT 指令时 |  |  |  |  |  |
|                  |                 |                     | 当 CPU 使用 XT1 时钟(fxт)时 当 CPU 使用外部子系统时钟(fexclks)时 |                   |  |  |  |  |  |
|                  |                 |                     |                                                 |                   |  |  |  |  |  |
| 系:               | 统时钟             |                     | 停止 CPU 时钟                                       |                   |  |  |  |  |  |
| 主系统时钟 frH        |                 | fкн                 | 保持设置 HALT 模式前的状态                                |                   |  |  |  |  |  |
|                  | fx              |                     |                                                 |                   |  |  |  |  |  |
| 子系统时钟            |                 | fexclk              | 由外部时钟输入进行操作或停止                                  |                   |  |  |  |  |  |
|                  |                 | fхт                 | 操作继续 (不能停止)                                     | 由外部时钟输入进行操作或停止    |  |  |  |  |  |
|                  |                 | fexclks             | 由外部时钟输入进行操作或停止                                  | 操作继续 (不能停止)       |  |  |  |  |  |
|                  | f <sub>RL</sub> |                     | 由外部时钟输入进行操作或停止                                  |                   |  |  |  |  |  |
| CF               | บ               |                     | 操作停止                                            |                   |  |  |  |  |  |
| Fla              | ish 存储器         |                     | 操作停止                                            |                   |  |  |  |  |  |
| RA               | M               |                     | 保持设置 HALT 模式前的状态                                |                   |  |  |  |  |  |
| 端                | 口(锁存器)          |                     | 保持设置 HALT 模式前的状态                                | 保持设置 HALT 模式前的状态  |  |  |  |  |  |
| 16               | 位定时器/事件计        | 数 00 <sup>2</sup>   | 可操作                                             |                   |  |  |  |  |  |
| 器                |                 | 01 <sup>推</sup>     |                                                 |                   |  |  |  |  |  |
| 8 1              | 立定时器/事件计数       | 效器 50 <sup>推</sup>  |                                                 |                   |  |  |  |  |  |
|                  | 51 *            |                     |                                                 |                   |  |  |  |  |  |
| 8 1              | 立定时器            | H0                  | ]                                               |                   |  |  |  |  |  |
|                  |                 | H1                  |                                                 |                   |  |  |  |  |  |
| 钟                | 表定时器            | •                   |                                                 |                   |  |  |  |  |  |
| 看                | 门狗定时器           |                     | 可操作。当通过可选字节设置"可以由软件停止内部低速振荡器"时,停止看门狗定时器的时钟。     |                   |  |  |  |  |  |
| 时                | <br>钟输出         |                     | 可操作                                             |                   |  |  |  |  |  |
| 蜂                | 鸣器输出            |                     | 可操作。但当停止外部硬件时钟(fprs)时,禁止操作。                     |                   |  |  |  |  |  |
| A/[              | D转换器            |                     |                                                 |                   |  |  |  |  |  |
|                  | 行接口             | UART0               | 可操作                                             |                   |  |  |  |  |  |
|                  |                 | UART6               | 1                                               |                   |  |  |  |  |  |
|                  |                 | CSI10 <sup>2±</sup> | 1                                               |                   |  |  |  |  |  |
|                  |                 | CSI11 *             | 1                                               |                   |  |  |  |  |  |
|                  |                 | CSIA0 <sup>≇</sup>  | 1                                               |                   |  |  |  |  |  |
|                  |                 | IIC0 <sup>½</sup>   | 1                                               |                   |  |  |  |  |  |
| 乘                | 法器/除法器          |                     | 1                                               |                   |  |  |  |  |  |
|                  | 电清零(POC) り      | 力能                  | 1                                               |                   |  |  |  |  |  |
|                  | 电压检测功能          |                     | 1                                               |                   |  |  |  |  |  |
| (以电压检测功能<br>外部中断 |                 |                     | 1                                               |                   |  |  |  |  |  |

★注: 当 CPU 使用子系统时钟且内部高速振荡时钟已经停止时,不要启动使用外部时钟的外部硬件的功能。

**备注:** 内部高速振荡时钟

fx: X1 时钟

fexclk: 外部主系统时钟

fxT: XT1 时钟

 fexclks:
 外部子系统时钟

 fkl:
 内部低速振荡时钟

# (2) 释放 HALT 模式

以下两种中断源可以释放 HALT 模式。

# (a) 由没有被屏蔽的中断请求释放

当产生一个没有被屏蔽的中断时,释放 HALT 模式。如果允许响应中断,则执行向量中断服务程序。如果禁止响应中断,则执行下一个地址的指令。

图 22-3 通过产生中断请求释放 HALT 模式



#### 备注:

- 1. 虚线表示释放待机模式的中断请求被响应的情况。
- 2. 等待时间如下所示:
  - 执行向量中断服务程序时: 8 或 9 个 时钟周期
  - 不执行向量中断服务程序时: 2或3个时钟周期

# (b) 通过产生的复位信号释放

当产生复位信号时,释放 HALT模式,然后在进行正常复位操作后,程序从复位向量指向的地址处开始执行。

#### 图 22-4 通过复位释放 HALT 模式

#### (1) CPU 使用高速系统时钟



# (2) CPU 使用内部高速振荡时钟



# (3) CPU 使用子系统时钟



**备注:** fx: X1 时钟振荡频率

表 22-2 在 HALT 模式中与中断请求对应的操作

| 释放源     | MK×× | PR×× | ΙE | ISP | 操作         |
|---------|------|------|----|-----|------------|
| 可屏蔽中断请求 | 0    | 0    | 0  | ×   | 执行下一个地址的指令 |
|         | 0    | 0    | 1  | ×   | 执行中断服务程序   |
|         | 0    | 1    | 0  | 1   | 执行下一个地址的指令 |
|         | 0    | 1    | ×  | 0   |            |
|         | 0    | 1    | 1  | 1   | 执行中断服务程序   |
|         | 1    | ×    | ×  | ×   | 保持 HALT 模式 |
| 复位      | -    | -    | ×  | ×   | 复位处理       |

×: 不必考虑

#### 22.2.2 STOP 模式

# (1) STOP 模式设置及操作状态

通过执行 STOP 指令设置 STOP 模式。仅当设置 STOP 模式前 CPU 使用主系统时钟时才可以设置 STOP 模式。

注意事项:由于中断请求信号用于释放待机模式,因此如果一个中断源的中断请求标志被设置且中断屏蔽标志被清零时,则立即释放待机模式。因此,在执行 STOP 指令后,立即将 STOP 模式复位到 HALT 模式,并且在经历了 OSTS 设置的等待时间后,系统返回操作模式。

STOP模式中的操作状态如下所示。

# 表 22-3 STOP 模式中的操作状态

|             |          | 衣 22-3 510 / 传                                                                                       | (2/ 1 H17X1L-M/12) |           |  |  |  |  |  |
|-------------|----------|------------------------------------------------------------------------------------------------------|--------------------|-----------|--|--|--|--|--|
| ST          | 「OP 模式设置 | 当 CPU 使用主系统时钟并执行 STOP 指令时                                                                            |                    |           |  |  |  |  |  |
| ***         |          | 当 CPU 使用内部高速振荡时<br>钟(fRH)时       当 CPU 使用 X1 时钟(fx)时<br>(fexclx)时       当 CPU 使用外部主系统时钟<br>(fexclx)时 |                    |           |  |  |  |  |  |
| 项目          |          |                                                                                                      |                    |           |  |  |  |  |  |
| 系统时钟        |          | 停止 CPU 时钟                                                                                            |                    |           |  |  |  |  |  |
| 主系统时钟       | fкн      | 停止                                                                                                   |                    |           |  |  |  |  |  |
|             | fx       | th ) T.M.                                                                                            |                    |           |  |  |  |  |  |
| 75 W 114 M  | fexclk   | 输入无效                                                                                                 |                    |           |  |  |  |  |  |
| 子系统时钟       | fхт      | 保持设置 STOP 模式前的状态<br>由外部时钟输入进行操作或停止                                                                   |                    |           |  |  |  |  |  |
| £           | fexclks  | 保持设置 STOP 模式前的状态                                                                                     |                    | _         |  |  |  |  |  |
| CPU         |          | 操作停止                                                                                                 |                    |           |  |  |  |  |  |
| 闪存          |          | 操作停止                                                                                                 |                    |           |  |  |  |  |  |
| RAM         |          | 保持设置 STOP 模式前的状态                                                                                     |                    |           |  |  |  |  |  |
| 端口 (锁存器)    |          | 保持设置STOP模式前的状态                                                                                       |                    |           |  |  |  |  |  |
| 16 位定时器/事件记 | 十数 00    | 操作停止                                                                                                 |                    |           |  |  |  |  |  |
| 器           | 01       | DNI 17 III                                                                                           |                    |           |  |  |  |  |  |
| 8位定时器/事件计   |          | 仅当选择 TI50 作为计数时钟时可操作                                                                                 |                    |           |  |  |  |  |  |
|             | 51       | 仅当选择 TI51 作为计数时钟时可操作                                                                                 |                    |           |  |  |  |  |  |
| 8位定时器       | H0       | 在8位定时器/事件计数器 50 操作期间,仅当选择 TM50 输出作为计数时钟时可操作                                                          |                    |           |  |  |  |  |  |
|             | H1       | 仅当选择 frL, frL/2 <sup>7</sup> , frL/2 <sup>9</sup> 作为计数时钟时可操作                                         |                    |           |  |  |  |  |  |
| 钟表定时器       | •        | 仅当选择子系统时钟作为计数时钟时可操作                                                                                  |                    |           |  |  |  |  |  |
| 看门狗定时器      |          | 可操作。当可选字节设置"可由软件停止内部低速振荡器"时,停止看门狗定时器的时钟。                                                             |                    |           |  |  |  |  |  |
| 时钟输出        |          | 仅当选择子系统时钟作为计数时钟时可操作                                                                                  |                    |           |  |  |  |  |  |
| 蜂鸣器输出       |          | 操作停止                                                                                                 |                    |           |  |  |  |  |  |
| A/D 转换器     |          |                                                                                                      |                    |           |  |  |  |  |  |
| 串行接口        | UART0    | 在8位定时器/事件计数器50操作                                                                                     | 作期间,仅当选择 TM50 输出作为 | 的计数时钟时可操作 |  |  |  |  |  |
|             | UART6    | 仅当选择外部时钟作为串行时钟时可操作                                                                                   |                    |           |  |  |  |  |  |
|             | CSI10    |                                                                                                      |                    |           |  |  |  |  |  |
|             | CSI11    |                                                                                                      |                    |           |  |  |  |  |  |
|             | CSIA0    | 4                                                                                                    |                    |           |  |  |  |  |  |
|             | IIC0     |                                                                                                      |                    |           |  |  |  |  |  |
| 乘法器/除法器     | .1. 414  | 操作停止                                                                                                 |                    |           |  |  |  |  |  |
| 上电清零(POC)   | 功能       | 可操作                                                                                                  |                    |           |  |  |  |  |  |
| 低电压检测功能     |          | 4                                                                                                    |                    |           |  |  |  |  |  |
| 外部中断        |          |                                                                                                      |                    |           |  |  |  |  |  |

**备注:** 内部高速振荡时钟

fx: X1 时钟

fexclk: 外部主系统时钟

fxT: XT1 时钟

 fexclks:
 外部子系统时钟

 fkl:
 内部低速振荡时钟

- 注意事项: 1. 在 STOP 模式释放后,要使用在 STOP 模式下停止操作的外部硬件,以及在 STOP 模式下时钟停止操作的外部硬件,必须重新启动外部硬件。
  - 2. 即使通过可选字节选择"可由软件停止内部低速振荡器",在 STOP 模式下,内部低速振荡时钟仍继续振荡,并保持 STOP 模式设置前的状态。要在 STOP 模式下停止内部低速振荡器的振荡,应通过软件停止该振荡器,然后执行 STOP 指令。
  - 3. 当 CPU 使用高速系统时钟(X1 振荡)时,为了在 STOP 模式释放后缩短振荡稳定时间,可在执行 STOP 指令前将 CPU 时钟暂时切换到内部高速振荡时钟。STOP 模式释放后,在将 CPU 时钟从高速振荡时钟 切换到高速系统时钟 (X1 振荡) 之前,应使用振荡稳定时间计数器的状态寄存器(OSTC)检测振荡稳定时间。
  - 4. 当 CPU 使用内部高速振荡时钟或外部主系统时钟时,如果 AMPH=1 时执行 STOP 指令,则在 STOP 模式释放后,CPU 使用内部高速振荡时钟或外部主系统时钟的时间为 5 μs (MIN.)。

#### (2) 释放 STOP 模式

## 图 22-5 释放 STOP 模式时的操作时序



#### 注: 当 AMPH = 1

可通过以下两类中断源释放 STOP 模式。

## (a) 由没有被屏蔽的中断请求释放

当产生一个没有被屏蔽的中断请求时,释放 STOP 模式。经历振荡稳定时间后,如果允许响应中断,则执行向量中断服务程序。如果禁止响应中断,则执行下一个地址的指令。

## 图 22-6 通过产生中断请求释放 STOP 模式

# (1) 当 CPU 使用高速系统时钟时



## (2) 当 CPU 使用高速振荡时钟



**备注:** 虚线表示释放待机模式的中断请求被响应的情况。

## (b) 由复位信号的产生释放

当产生复位信号时,释放 STOP 模式,然后在正常复位操作情况下,当程序转向复位向量地址后执行之。

## 图 22-7 由复位释放 STOP 模式

## (1) 当 CPU 使用高速系统时钟



# (2) 当 CPU 使用内部高速振荡时钟



# **备注:** fx: X1 时钟振荡频率

表 22-4 在 STOP 模式中与中断请求对应的操作

| 释放源      | MK×× | PR×× | ΙE | ISP | 操作         |
|----------|------|------|----|-----|------------|
| 可屏蔽的中断请求 | 0    | 0    | 0  | ×   | 执行下一个地址的指令 |
|          | 0    | 0    | 1  | ×   | 执行中断服务程序   |
|          | 0    | 1    | 0  | 1   | 执行下一个地址的指令 |
|          | 0    | 1    | ×  | 0   |            |
|          | 0    | 1    | 1  | 1   | 执行中断服务程序   |
|          | 1    | ×    | ×  | ×   | 保持 STOP 模式 |
| 复位       | -    | -    | ×  | ×   | 复位处理       |

×: 不必考虑

#### 第二十三章 复位功能

以下4种操作用于产生复位信号。

- (1) 由 RESET 引脚输入的外部复位信号
- (2) 由看门狗定时器程序循环检测引起的内部复位
- (3) 通过比较上电清零(POC)电路的检测电压和供电电压引起的内部复位
- (4) 通过比较低电压检测电路(LVI)的检测电压和供电电压引起的内部复位

外部复位与内部复位在功能上没有什么区别。在这两种情况中,当产生复位信号时,程序都是从地址 0000H 和0001H 处开始执行。

当 RESET 引脚输入为低电平、看门狗定时器溢出或 POC 和 LVI 电路的电压检测都可以引起复位,每项硬件的设置 状态如表 23-1 和 23-2 所示。在复位信号产生期间或在复位释放后振荡稳定时间内,除 P130(低电平输出)以外,每个引脚均为高阻抗。

当 RESET 引脚输入低电平时,设备被复位。当 RESET 引脚输入高电平时,设备从复位状态释放,并在复位处理后使用内部高速振荡时钟执行程序。由看门狗定时器引起的复位自动释放,并在复位处理后使用内部高速振荡时钟执行程序(参见图 23-2 ~ 23-4)。由 POC 和 LVI 电路供电电压检测引起的复位,在复位后,当 VDD > VPOC 或 VDD > VLVI时自动释放,并使用内部高速振荡时钟执行程序(参见第二十四章 上电清零电路 和第二十五章 低电压检测电路)。

注意事项: 1. 对于外部复位,输入 $\overline{RESET}$ 引脚的低电平的时间至少应为 10  $\mu$ s。

- 2. 复位输入期间, X1 时钟、XT1 时钟、内部高速振荡时钟和内部低速振荡时钟停止振荡。外部主系统时钟输入和外部子系统时钟输入无效。
- 3. 在通过复位释放 STOP 模式时,复位输入期间保持 STOP 模式的内容。但 P130(低电平输出)除外的端口引脚变为高阻态。



注意事项: LVI 电路内部复位功能不能复位 LVI 电路。

备注: 1. LVIM: 低电压检测寄存器

2. LVIS: 低电压检测等级选择寄存器

## 图 23-2 由 RESET 输入进行复位的时序



注: 由软件将 P130 设置为高电平输出。

**备注:** 当复位有效时,P130 的输出为低电平。如果在复位有效前将P130 设置为高电平输出,则P130 的输出信号可以作为虚拟的CPU复位信号。

#### 图 23-3 由于看门狗定时器溢出进行复位的时序



注: 由软件将 P130 设置为高电平输出。

#### 注意事项:看门狗定时器内部复位功能也可以复位看门狗定时器。

**备注:** 当复位有效时,P130 的输出为低电平。如果在复位有效前将P130 设置为高电平输出,则P130 的输出信号可以作为虚拟的CPU 复位信号。

## 图 23-4 在 STOP 模式下通过 RESET 输入进行复位的时序



注: 由软件将 P130 设置为高电平输出。

- **备注:** 1. 当复位有效时,P130 的输出为低电平。如果在复位有效前将P130 设置为高电平输出,则P130 的输出信号可以作为虚拟的CPU复位信号。
  - **2.** 如需了解上电清零(POC)电路和低电压检测电路的复位时序,可参见 第二十四章 上电清零电路 和第二十五章 低电压检测电路。

# 表 23-1 复位期间的操作状态

| Г    | _+                                                                  |        | 衣 23-1 复位别问的探行 (人)         |  |  |
|------|---------------------------------------------------------------------|--------|----------------------------|--|--|
| L    | 项目                                                                  |        | 复位期间                       |  |  |
| į    | 系统时钟                                                                |        | 停止 CPU 时钟                  |  |  |
|      | 主系统时钟 frH fx                                                        |        | 停止操作<br>停止操作(引脚为 I/O 端口模式) |  |  |
|      |                                                                     |        |                            |  |  |
|      |                                                                     | fexclk | 时钟输入无效 (引脚为 I/O 端口模式)      |  |  |
|      | 子系统时钟                                                               | fхт    | 停止操作 (引脚为 I/O 端口模式)        |  |  |
|      |                                                                     | fexclk | 时钟输入无效 (引脚为 I/O 端口模式)      |  |  |
|      | frL                                                                 |        | 停止操作                       |  |  |
| (    | CPU                                                                 |        |                            |  |  |
| ĺ    | 闪存                                                                  |        |                            |  |  |
| F    | RAM                                                                 |        |                            |  |  |
| j    | 端口 (锁存器)                                                            |        | 停止操作                       |  |  |
|      | 16 位定时器/事件记                                                         | 十数 00  |                            |  |  |
| 1    | 器                                                                   | 01     |                            |  |  |
| 8    | 8 位定时器/事件计数器     50       51     8 位定时器       H0     H1       钟表定时器 |        |                            |  |  |
|      |                                                                     |        |                            |  |  |
| 8    |                                                                     |        |                            |  |  |
|      |                                                                     |        |                            |  |  |
| 4    |                                                                     |        |                            |  |  |
| 17   | <b>看门狗定时器</b>                                                       |        |                            |  |  |
| k [  | 时钟输出                                                                |        |                            |  |  |
| k j  | 峰鸣器输出                                                               |        |                            |  |  |
| 1    | VD 转换器                                                              |        |                            |  |  |
| 1    | 串行接口                                                                | UART0  |                            |  |  |
|      |                                                                     | UART6  |                            |  |  |
|      |                                                                     | CSI10  |                            |  |  |
|      | CSI11<br>CSIA0<br>IIC0                                              |        |                            |  |  |
|      |                                                                     |        |                            |  |  |
| L    |                                                                     |        |                            |  |  |
| 11.7 | 乘法器/除法器                                                             |        |                            |  |  |
| L    | 上电清零功能                                                              |        | 可操作                        |  |  |
| 1    | 低电压检测功能                                                             |        | 停止操作                       |  |  |
| 2    | 外部中断                                                                |        |                            |  |  |
| _    |                                                                     |        |                            |  |  |

**备注:** 内部高速振荡时钟

 fx:
 X1 振荡时钟

 fexclk:
 外部主系统时钟

 fxT:
 XT1 振荡时钟

 fexclks:
 外部子系统时钟

 fRL:
 内部低速振荡时钟

## 表 23-2 响应复位后的硬件状态 (1/3)

|                | 硬件                                                       | 响应复位后的状态 <sup>#1</sup> |
|----------------|----------------------------------------------------------|------------------------|
| 程序计数器(PC)      | 设置复位向量表的内容<br>(0000H、0001H)                              |                        |
| 堆栈指针 (SP)      |                                                          | 不确定                    |
| 程序状态字(PSW)     |                                                          | 02H                    |
| RAM            | 数据存储器                                                    | 不确定 <sup>推2</sup>      |
|                | 通用寄存器                                                    | 不确定 <sup>推2</sup>      |
| 端口寄存器 (P0 ~ P7 | 、P12~P14) (输出锁存器)                                        | 00H                    |
| 端口模式寄存器 (PM0   | $\sim$ PM7, PM12, PM14)                                  | FFH                    |
| 上拉电阻选择寄存器 (F   | PU0, PU1, PU3 ~ PU7, PU12, PU14)                         | 00H                    |
| 内部扩展 RAM 容量切   | 换寄存器(IXS)                                                | 0CH <sup>2±3</sup>     |
| 内存容量切换寄存器(II   | MS)                                                      | CFH <sup>±3</sup>      |
| 存储器组选择寄存器 (图   | BANK)                                                    | 00H                    |
| 时钟操作模式选择寄存     | 器 (OSCCTL)                                               | 00H                    |
| 处理器时钟控制寄存器     | (PCC)                                                    | 01H                    |
| 内部振荡模式寄存器(R    | CCM)                                                     | 80H                    |
| 主 OSC 控制寄存器(MC | DC)                                                      | 80H                    |
| 主时钟模式寄存器(MC    | M)                                                       | 00H                    |
| 振荡稳定时间计数器的     | 状态寄存器(OSTC)                                              | 00H                    |
| 振荡稳定时间选择寄存     | 器(OSTS)                                                  | 05H                    |
| 16位定时器/事件计数    | 定时器计数器 00, 01 (TM00, TM01)                               | 0000H                  |
| 器 00、 01       | 捕捉/比较寄存器 000, 010, 001, 011 (CR000, CR010, CR001, CR011) | 0000H                  |
|                | 模式控制寄存器 00, 01 (TMC00, TMC01)                            | 00H                    |
|                | 预分频器模式寄存器 00, 01 (PRM00, PRM01)                          | 00H                    |
|                | 捕捉/比较控制寄存器 00, 01 (CRC00, CRC01)                         | 00H                    |
|                | 定时器输出控制寄存器 00, 01 (TOC00, TOC01)                         | 00H                    |
| 8位定时器/事件计数     | 定时器计数器 50, 51 (TM50, TM51)                               | 00H                    |
| 器 50, 51       | 比较寄存器 50, 51 (CR50, CR51)                                | 00H                    |
|                | 定时器时钟选择寄存器 50, 51 (TCL50, TCL51)                         | 00H                    |
|                | 模式控制寄存器 50, 51 (TMC50, TMC51)                            | 00H                    |

- **注:** 1. 在复位信号产生或振荡稳定时间等待期间,硬件状态中只有 PC 内容不确定。复位后其它硬件状态保持不变。
  - 2. 当在待机模式中进行复位时,即使复位后也保持复位前的状态。
  - 3. 在所有 78K0/KF2 产品中,无论内存容量如何,当复位释放后内存容量切换寄存器(IMS)和内部扩展 RAM 容量切换寄存器(IXS)的初值为常数(IMS = CFH, IXS = 0CH)。因此复位释放后必须为每个产品设置以下值。

| 闪存版本 (78K0/KF2)      | IMS | IXS |
|----------------------|-----|-----|
| μPD78F0544           | ССН | 0AH |
| μPD78F0545           | CFH | 08H |
| μPD78F0546           | ССН | 04H |
| μPD78F0547, 78F0547D | ССН | 00H |

# 表 23-2 响应复位后的硬件状态(2/3)

|                   | 硬件                                                | 响应复位后的状态**1  |
|-------------------|---------------------------------------------------|--------------|
| 8 位定时器 H0, H1     | 比较寄存器 00, 10, 01, 11 (CMP00, CMP10, CMP01, CMP11) | 00H          |
| , , _ ,           | 模式寄存器 (TMHMD0, TMHMD1)                            | 00H          |
|                   | 载波控制寄存器 1 (TMCYC1) <sup>#2</sup>                  | 00H          |
| 钟表定时器             | 操作模式寄存器(WTM)                                      | 00H          |
| 时钟输出/蜂鸣器输出控制<br>器 | 时钟输出选择寄存器 (CKS)                                   | 00Н          |
| 看门狗定时器            | 使能寄存器 (WDTE)                                      | 1AH/9AH ** 3 |
| A/D 转换器           | 10 位 A/D 转换结果寄存器 (ADCR)                           | 0000H        |
|                   | 8 位 A/D 转换结果寄存器(ADCRH)                            | 00H          |
|                   | 模式寄存器 (ADM)                                       | 00H          |
|                   | 模拟输入通道选择寄存器(ADS)                                  | 00H          |
|                   | A/D 端口配置寄存器 (ADPC)                                | 00H          |
| 串行接口 UART0        | 接收缓冲寄存器 0 (RXB0)                                  | FFH          |
|                   | 发送移位寄存器 0 (TXS0)                                  | FFH          |
|                   | 异步串行接口操作模式寄存器 0 (ASIM0)                           | 01H          |
|                   | 异步串行接口接收错误状态寄存器 0 (ASIS0)                         | 00H          |
|                   | 波特率发生器控制寄存器 0 (BRGC0)                             | 1FH          |
| 串行接口 UART6        | 接收缓冲寄存器 6 (RXB6)                                  | FFH          |
|                   | 发送缓冲寄存器 6 (TXB6)                                  | FFH          |
|                   | 异步串行接口操作模式寄存器 6 (ASIM6)                           | 01H          |
|                   | 异步串行接口接收错误状态寄存器 6 (ASIS6)                         | 00H          |
|                   | 异步串行接口发送状态寄存器 6 (ASIF6)                           | 00H          |
|                   | 时钟选择寄存器 6 (CKSR6)                                 | 00H          |
|                   | 波特率发生器控制寄存器 6 (BRGC6)                             | FFH          |
|                   | 异步串行接口控制寄存器 6 (ASICL6)                            | 16H          |
|                   | 输入切换控制寄存器 (ISC)                                   | 00H          |
| 串行接口 CSI10, CSI11 | 发送缓冲寄存器 10, 11 (SOTB10, SOTB11)                   | 00H          |
|                   | 串行 I/O 移位寄存器 10, 11 (SIO10, SIO11)                | 00H          |
|                   | 串行操作模式寄存器 10, 11 (CSIM10, CSIM11)                 | 00H          |
|                   | 串行时钟选择寄存器 10, 11 (CSIC10, CSIC11)                 | 00H          |
| 串行接口 CSIA0        | 串行操作模式选择寄存器 0 (CSIMA0)                            | 00H          |
|                   | 串行状态寄存器 0 (CSISO)                                 | 00H          |
|                   | 串行触发寄存器 0 (CSIT0)                                 | 00H          |
|                   | 除数选择寄存器 0 (BRGCA0)                                | 03H          |
|                   | 自动数据传送地址指针指定寄存器 0 (ADTP0)                         | 00H          |
|                   | 自动数据传送间隔指定寄存器 0 (ADTI0)                           | 00H          |
|                   | 串行 I/O 移位寄存器 0 (SIOA0)                            | 00H          |
|                   | 自动数据传送地址计数寄存器 0 (ADTC0)                           | 00H          |

- **注:** 1. 在复位信号产生或振荡稳定时间等待期间,硬件状态中只有 PC 内容不确定。复位后其它硬件状态保持不变。
  - 2. 仅用于 8 位定时器 H1。
  - **3.** 通过设置选项字节确定 WDTE 的复位值。

表 23-2 响应复位后的硬件状态(3/3)

|           | 硬件                                                 | 响应复位后的状态#1         |
|-----------|----------------------------------------------------|--------------------|
| 串行接口 IIC0 | 移位寄存器 0 (IIC0)                                     | 00H                |
|           | 控制寄存器 0 (IICC0)                                    | 00H                |
|           | 从设备地址寄存器 0 (SVA0)                                  | 00H                |
|           | 时钟选择寄存器 0 (IICCL0)                                 | 00H                |
|           | 功能扩展寄存器 0 (IICX0)                                  | 00H                |
|           | 状态寄存器 0 (IICS0)                                    | 00H                |
|           | 标志寄存器 0 (IICF0)                                    | 00H                |
| 乘法器/除法器   | 余数寄存器 0 (SDR0)                                     | 0000H              |
|           | 乘/除数寄存器 A0 (MDA0H, MDA0L)                          | 0000H              |
|           | 乘/除数寄存器 B0 (MDB0)                                  | 0000H              |
|           | 乘法器/除法器控制寄存器 0 (DMUC0)                             | 00H                |
| 按键中断      | 按键返回模式寄存器(KRM)                                     | 00H                |
| 复位功能      | 复位控制标志寄存器 (RESF)                                   | 00H * 2            |
| 低电压检测电路   | 低电压检测寄存器(LVIM)                                     | 00H <sup>推 2</sup> |
|           | 低电压检测等级选择寄存器 (LVIS)                                | 00H * 2            |
| 中断        | 请求标志寄存器 OL, OH, 1L, 1H (IFOL, IFOH, IF1L, IF1H)    | 00H                |
|           | 掩膜标志寄存器 OL, OH, 1L, 1H (MKOL, MKOH, MK1L, MK1H)    | FFH                |
|           | 优先级指定标志寄存器 0L, 0H, 1L, 1H (PR0L, PR0H, PR1L, PR1H) | FFH                |
|           | 外部中断上升沿使能寄存器(EGP)                                  | 00H                |
|           | 外部中断下降沿使能寄存器(EGN)                                  | 00H                |

- **注:** 1. 在复位信号产生或振荡稳定时间等待期间,硬件状态中只有 PC 内容不确定。复位后其它硬件状态保持不变。
  - 2. 这些值依据复位源的不同而变化。

|      | 复位源     | RESET 输入 | 由 POC 进行复 | 由 WDT 进行复 | 由 LVI 进行复位 |
|------|---------|----------|-----------|-----------|------------|
| 寄存器  |         |          | 位         | 位         |            |
| RESF | WDTRF 位 | 清零(0)    | 清零(0)     | 设置 (1)    | 保持         |
|      | LVIRF 位 |          |           | 保持        | 设置 (1)     |
| LVIM |         | 清零(00H)  | 清零 (00H)  | 清零(00H)   | 保持         |
| LVIS |         |          |           |           |            |

\*

# 23.1 确认复位源的寄存器

78K0/KF2中有许多内部复位源。复位控制标志寄存器(RESF)用于存储产生复位请求的复位源。可由 8 位存储器操作指令读取 RESF。

RESET 输入、由 POC 电路引起的复位输入以及读取 RESF 可将 RESF 清零(00H)。

图 23-5. 复位控制标志寄存器 (RESF) 的格式

地址: FFACH 复位后: 00H R

| 符号   | 7 | 6 | 5 | 4     | 3 | 2 | 1 | 0     |
|------|---|---|---|-------|---|---|---|-------|
| RESF | 0 | 0 | 0 | WDTRF | 0 | 0 | 0 | LVIRF |

| WDTRF | 看门狗定时器产生的内部复位请求(WDT) |
|-------|----------------------|
| 0     | 不产生内部复位请求,或对 RESF 清零 |
| 1     | 产生内部复位请求             |

| LVIRF | 由低电压检测电路(LVI)产生的内部复位请求 |
|-------|------------------------|
| 0     | 不产生内部复位请求,或对 RESF 清零   |
| 1     | 产生内部复位请求               |

注: 复位后的值依据复位源而变化。

注意事项: 不能通过1位存储器操作指令读取数据。

产生复位请求时的 RESF 状态如表 23-3 所示。

表 23-3 产生复位请求时的 RESF 状态

|       | ** · · / — / | <b></b>   | 7 ***     |            |
|-------|--------------|-----------|-----------|------------|
| 复位源   | RESET 输入     | 由 POC 引起的 | 由 WDT 引起的 | 由 LVI 引起的复 |
| 标志    |              | 复位        | 复位        | 位          |
| WDTRF | 清零(0)        | 清零(0)     | 设置(1)     | 保持         |
| LVIRF |              |           | 保持        | 设置 (1)     |

# 第二十四章 上电清零电路

#### 24.1 上电清零电路的功能

上电清零电路 (POC) 有以下功能。

- 在上电时产生内部复位信号。
   在 1.59 V POC 模式下(选项字节: POCMODE = 0), 当供电电压(VDD)超过 1.59 V ±0.15 V 时,释放复位信号。
   在 2.7 V/1.59 V POC 模式下(选项字节: POCMODE = 1),当供电电压(VDD)超过 2.7 V ±0.2 V 时,释放复位信号。
- 比较供电电压(V<sub>DD</sub>)和检测电压(V<sub>POC</sub> = 1.59 V ±0.15 V),并在 V<sub>DD</sub> < V<sub>POC</sub> 时产生内部复位信号,而在 V<sub>DD</sub> ≥ V<sub>POC</sub> 时释放复位状态。

注意事项: 如果由 POC 电路产生内部复位信号,则将复位控制标志寄存器(RESF)清零(00H)。

**备注:** 该产品集成了多种可以产生内部复位信号的硬件功能。RESF 中有一个标志用于指示复位源,用于看门狗 定时器(WDT)或低电压检测电路(LVI)产生的内部复位信号。当 WDT 或 LVI 产生内部复位信号时,不对 RESF 清零(00H),标志位被设置为 1。

如需了解 RESF 的详细内容,参见第二十三章 复位功能。

## 24.2 上电清零电路的配置

上电清零电路的框图如图 24-1 所示。

图 24-1. 上电清零电路的框图



## ★24.3 上电清零电路的操作

## (1) 1.59 V POC 模式 (选项字节: POCMODE = 0)

- 上电时产生内部复位信号。当供电电压(Vpp)超过检测电压(Vpoc = 1.59 V ±0.15 V)时,释放复位状态。
- 比较供电电压(VpD)和检测电压(VPOC = 1.59 V ±0.15 V)。当 VpD < VPOC 时,产生内部复位信号。当 VpD ≥ VPOC, 释放内部复位信号。

# (2) 2.7 V/1.59 V POC 模式 (选项字节: POCMODE = 1)

- 上电时产生内部复位信号。当供电电压(Vpp)超过检测电压(Vpppoc = 2.7 V ±0.2 V)时,释放复位状态。
- 比较供电电压(V<sub>DD</sub>)和检测电压(V<sub>POC</sub> = 1.59 V ±0.15 V)。当 V<sub>DD</sub> < V<sub>POC</sub>时,产生内部复位信号。当 V<sub>DD</sub> ≥ V<sub>POC</sub>时,释放内部复位信号。

由上电清零电路和低电压检测电路产生内部复位信号的时序如下所示。

Figure 24-2. 由上电清零电路和低电压检测电路产生内部复位信号的时序 (1/2)

# (1) 1.59 V POC 模式 (选项字节: POCMODE = 0)



- **注:** 1. 保证操作的电压范围:  $1.8 \text{ V} \leq \text{V}_{DD} \leq 5.5 \text{ V}_{o}$  当供电电压下降时,为使状态低于 1.8 V 复位状态,可以使用低电压检测电路的复位功能,或通过  $\overline{\text{RESET}}$  引脚输入低电平。
  - **2.** 如果在上电时速率低于 0.5 V/ms (MAX.)时电压上升至 1.8 V,则在上电后且电压上升到 1.8 V 之前向 RESET 引脚输入低电平,或使用选项字节(POCMODE = 1)设置 2.7 V/1.59 V POC 模式。
  - 3. 可以选择内部高速振荡时钟和一个高速系统时钟或一个子系统时钟作为 CPU 时钟。如果要使用 X1 时钟,可以通过 OSTC 确认是否经历了振荡稳定时间。而如果要使用 XT1 时钟,可以通过定时器功能来确认是否经历了振荡稳定时间。

注意事项: 在释放复位状态后通过软件设置低电压检测电路 (参见第二十五章 低电压检测电路)。

**备注:** VLVI: LVI 检测电压

Vpoc: POC 检测电压

## 图 24-2 由上电清零电路和低电压检测电路产生内部复位信号的时序(2/2)

# (2) 2.7 V/1.59 V POC 模式 (选项字节: POCMODE = 1)



- **注:** 1. 保证操作的电压范围:  $1.8 \text{ V} \leq \text{V}_{DD} \leq 5.5 \text{ V}_{o}$  当供电电压下降时,为使状态低于 1.8 V 复位状态,可以使用低电压检测电路的复位功能,或向  $\overline{\text{RESET}}$  引脚输入低电平。
  - 2. 可以选择内部高速振荡时钟和一个高速系统时钟或一个子系统时钟作为 CPU 时钟。如果要使用 X1 时钟,可以通过 OSTC 确认是否经历了振荡稳定时间。而如果要使用 XT1 时钟,可以通过定时器功能来确认是否经历了振荡稳定时间。

注意事项: 在释放复位状态后通过软件设置低电压检测电路 (参见第二十五章 低电压检测电路)。

**备注:** VLVI: LVI 检测电压

VPOC: POC 检测电压

## 24.4 上电清零电路使用注意事项

在系统中,如果供电电压(VDD)接近 POC 检测电压(VPOC)时的一段时间内产生波动,则系统可能会反复复位和释放复位。在这种情况下,可采用下列方法任意设置从复位释放到微控制器的启动所需要的时间。

#### <方法>

在释放复位信号后,通过软件计数器(使用一个定时器)等待系统供电电压的波动期,然后对端口初始化。

## 图 24-3. 复位释放后软件处理过程示例 (1/2)

• 如果供电电压接近 POC 检测电压, 其波动时间≤50 ms。



- 注: 1. 如果在此期间再次产生复位,则不启动初始化操作<2>。
  - 2. 流程图显示在下页。

# 图 24-3 复位释放后软件处理过程示例(2/2)

# • 检查复位原因



## 第二十五章 低电压检测电路

#### 25.1 低电压检测电路的功能

低电压检测电路 (LVI) 有以下功能。

- 比较供电电压(VDD)和检测电压(VLVI), 当 VDD < VLVI时,并产生内部中断信号或内部复位信号。可由软件改变供电电压的检测等级(16 个等级)。
- 比较外部输入引脚的输入电压(EXLVI)与检测电压(VexLvI = 1.21 V (TYP.)),并在 EXLVI < VexLvI 时产生内部中断信号或内部复位信号。
- 可由软件选择供电电压(VDD)或外部输入引脚的输入电压(EXLVI)。
- 可由软件选择中断或复位功能
- 在 STOP 模式下可操作

在使用低电压检测电路进行复位时,如果产生复位,则设置复位控制标志寄存器(RESF)的第 0 位(LVIRF)=1。 需要了解 RESF 的详细内容,可参见**第二十三章 复位功能。** 

## 25.2 低电压检测电路的配置

低电压检测电路的框图如图 25-1 所示。

#### **k**

图 25-1. 低电压检测电路的框图



559

# 25.3 控制低电压检测电路的寄存器

低电压检测电路由以下寄存器控制。

- 低电压检测寄存器 (LVIM)
- 低电压检测等级选择寄存器(LVIS)
- 端口模式寄存器 12 (PM12)

# (1) 低电压检测寄存器 (LVIM)

该寄存器用于设置低电压检测和操作模式。

可由1位或8位存储器操作指令设置该寄存器。

复位信号将 LVIM 清零(00H)。

# 图 25-2 低电压检测寄存器 (LVIM) 的格式

复位后: 00H R/W<sup>推1</sup> 地址: FFBEH 符号 <7> 6 5 4 3 <2> <1> <0> LVION 0 LVISEL LVIMD LVIF LVIM 0 0

| LVION *2,3 | 允许低电压检测操作 |
|------------|-----------|
| 0          | 禁止操作      |
| 1          | 允许操作      |

|   | LVISEL <sup>推2</sup> | 电压检测的选择                 |  |  |  |  |
|---|----------------------|-------------------------|--|--|--|--|
|   | 0                    | 测供电电压(VDD)的等级           |  |  |  |  |
| 1 | 1                    | 检测外部输入引脚的输入电压(EXLVI)的等级 |  |  |  |  |

| LVIMD <sup>注 2</sup> | 低电压检测操作模式的选择                                                                                                                                             |  |  |  |  |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0                    | ◆LVISEL = 0: 当供电电压(V <sub>DD</sub> ) < 检测电压 (V <sub>LVI</sub> )时产生中断信号<br>◆LVISEL = 1: 当外部输入引脚的输入电压(EXLVI) < 检测电压(V <sub>EXLVI</sub> )时,产生中断信号           |  |  |  |  |  |  |
| 1                    | ◆ LVISEL = 0: 当供电电压(V <sub>DD</sub> ) < 检测电压 (V <sub>LVI</sub> )时产生内部复位信号<br>◆ LVISEL = 1: 当外部输入引脚的输入电压(EXLVI) < 检测电压(V <sub>EXLVI</sub> )时,产生内部复位信<br>号 |  |  |  |  |  |  |

| LVIF <sup>注 4</sup> | 低电压检测标志                                                                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                   | <ul> <li>LVISEL = 0: 供电电压 (V<sub>DD</sub>) ≥ 检测电压 (V<sub>LVI</sub>)、或当禁止操作时</li> <li>LVISEL = 1: 外部输入引脚的输入电压(EXLVI) ≥ 检测电压(V<sub>EXLVI</sub>),或当禁止操作时</li> </ul> |
| 1                   | <ul><li>◆ LVISEL = 0: 供电电压 (V<sub>DD</sub>) &lt; 检测电压 (V<sub>LVI</sub>)</li><li>◆ LVISEL = 1: 外部输入引脚的输入电压(EXLVI) &lt; 检测电压(V<sub>EXLVI</sub>)</li></ul>          |

## 注: 1. 第0位只读。

- **2.** 在产生除 LVI 复位以外的复位时,LVION、LVIMD 和 LVISEL 被清零(0)。在产生 LVI 复位时这些位不被清零。
- 3. 当 LVION=1 时,LVI 电路中的比较器开始操作。从设置 LVION=1 到 LVIF 确定电压,使用软件等待操作稳定时间(10  $\mu$ s (MAX.))。
- **4.** 当 LVION = 1 且 LVIMD = 0 时,输出 LVIF 的值作为中断请求 INTLVI 的中断源。

#### 注意事项: 1. 在执行以下任一过程后,停止 LVI。

- ●当使用 8 位操作指令时: 00H → LVIM。
- ●当使用1位存储器操作指令时:对LVION清零。
- 2. 外部输入引脚的输入电压(EXLVI)必须为: EXLVI < VDD。

## (2) 低电压检测等级选择寄存器 (LVIS)

该寄存器用于选择低电压检测等级。 可由 1 位或 8 位存储器操作指令设置该寄存器。 复位信号将 LVIS 清零(00H)。

## 图 25-3. 低电压检测等级选择寄存器 (LVIS) 的格式

| 地址: F | FBFH | 复位后: 00 | H R/W |   |       |       |       |       |
|-------|------|---------|-------|---|-------|-------|-------|-------|
| 符号    | 7    | 6       | 5     | 4 | 3     | 2     | 1     | 0     |
| LVIS  | 0    | 0       | 0     | 0 | LVIS3 | LVIS2 | LVIS1 | LVIS0 |

| LVIS3 | LVIS2 | LVIS1 | LVIS0 | 检测等级                   |
|-------|-------|-------|-------|------------------------|
| 0     | 0     | 0     | 0     | VLVI0 (4.24 V ±0.1 V)  |
| 0     | 0     | 0     | 1     | VLVI1 (4.09 V ±0.1 V)  |
| 0     | 0     | 1     | 0     | VLVI2 (3.93 V ±0.1 V)  |
| 0     | 0     | 1     | 1     | VLVI3 (3.78 V ±0.1 V)  |
| 0     | 1     | 0     | 0     | VLVI4 (3.62 V ±0.1 V)  |
| 0     | 1     | 0     | 1     | VLVI5 (3.47 V ±0.1 V)  |
| 0     | 1     | 1     | 0     | VLVI6 (3.32 V ±0.1 V)  |
| 0     | 1     | 1     | 1     | VLVI7 (3.16 V ±0.1 V)  |
| 1     | 0     | 0     | 0     | VLVI8 (3.01 V ±0.1 V)  |
| 1     | 0     | 0     | 1     | VLVI9 (2.85 V ±0.1 V)  |
| 1     | 0     | 1     | 0     | VLVI10 (2.70 V ±0.1 V) |
| 1     | 0     | 1     | 1     | VLVI11 (2.55 V ±0.1 V) |
| 1     | 1     | 0     | 0     | VLVI12 (2.39 V ±0.1 V) |
| 1     | 1     | 0     | 1     | VLVI13 (2.24 V ±0.1 V) |
| 1     | 1     | 1     | 0     | VLVI14 (2.08 V ±0.1 V) |
| 1     | 1     | 1     | 1     | VLVI15 (1.93 V ±0.1 V) |

注意事项: 1. 第4~7位必须清零。

- 2. LVI 操作期间不要修改 LVIS 的值。
- 3. 当检测到外部输入引脚的输入电压(EXLVI)时,检测电压(VEXLVI = 1.21 V (TYP.))恒定。因此,不必设置 LVIS。

## (3) 端口模式寄存器 12 (PM12)

当使用 P120/EXLVI/INTP0 引脚进行外部低电压检测电压输入时,设置 PM120=1。此时, P120 的输出锁存器的值可以为 0 或 1。

可由 1 位或 8 位存储器操作指令设置 PM12。

复位信号将 PM12 设置为 FFH。

## 图 25-4 端口模式寄存器 12 (PM12)的格式

| 地址:F | F2CH | 复位后:FF | H R/W |       |       |       |       |       |
|------|------|--------|-------|-------|-------|-------|-------|-------|
| 符号:  | 7    | 6      | 5     | 4     | 3     | 2     | 1     | 0     |
| PM12 | 1    | 1      | 1     | PM124 | PM123 | PM122 | PM121 | PM120 |

| PM12n | P12n 引脚 I/O 模式的选择 (n = 0 $\sim$ 4) |  |  |  |  |
|-------|------------------------------------|--|--|--|--|
| 0     | 输出模式 (输出缓冲器打开)                     |  |  |  |  |
| 1     | 输入模式 (输出缓冲器关闭)                     |  |  |  |  |

## 25.4 低电压检测电路的操作

低电压检测电路能够用于以下两种模式。

#### (1) 用于复位

- 如果 LVISEL = 0,比较供电电压(VDD)与检测电压(VLVI),当 VDD < VLVI 时产生内部复位信号,而当 VDD ≥ VLVI 时释放内部复位。
- 如果 LVISEL = 1,比较外部输入引脚的输入电压(EXLVI)和检测电压(VexLvI = 1.21 V (TYP.)),在 EXLVI < VexLvI 时产生内部复位信号,而在 EXLVI ≥ VexLvI 时释放内部复位。

## (2) 用于中断

- 如果 LVISEL = 0,比较供电电压(VDD)和检测电压(VLVI),在 VDD < VLVI 时产生中断信号(INTLVI)。
- 如果 LVISEL = 1,比较比较外部输入引脚的输入电压(EXLVI)和检测电压(VexLVI = 1.21 V (TYP.)),在 EXLVI < VexLVI 时产生中断信号(INTLVI)。

备注: LVISEL: 低电压检测寄存器 (LVIM)的第2位

#### 25.4.1 用于复位

## (1) 当检测供电电压(VDD)等级时

- 启动操作时
  - <1> 屏蔽 LVI 中断 (LVIMK = 1)。
  - <2> 将低电压检测寄存器(LVIM)的第2位(LVISEL)清零(检测供电电压(VDD)的等级)(默认值)。
  - <3> 使用低电压检测等级选择寄存器(LVIS)的第  $3\sim0$  位(LVIS3  $\sim$  LVIS0)设置检测电压。
  - <4> 设置 LVIM 的第 7 位 (LVION) =1 (允许 LVI 的操作)。
  - <5> 使用软件等待操作稳定时间(10 μs (MAX.))。
  - <6> 等待直至根据 LVIM 的第 0 位(LVIF)检测到电压(供电电压(VDD) ≥ 检测电压(VLVI))。
  - <7> 设置 LVIM 的第 1 位 (LVIMD) =1 (当供电电压 (VDD) <检测电压 (VLVI) 时产生内部复位信号)。

图 25-5 显示了由低电压检测电路产生的内部复位信号的时序。该时序图中的标号与上面的<1> ~ <7>对应。

注意事项: 1. 必须执行过程<1>。当 LVIMK = 0 时,在过程<4>之后可能立即会产生中断。

- 2. 当 LVIM=1 时如果供电电压(VDD)≥检测电压(VLVI),则不会产生内部复位信号。
- 当停止操作时 必须执行以下过程之一。
  - 当使用 8 位存储器操作指令时:
     00H → LVIM
  - 当使用 1 位存储器操作指令时: 依次将 LVIMD 和 LVION 清零。

# 图 25-5 低电压检测电路内部复位信号产生时序 (检测供电电压(Vpp)等级) (1/2)

# (1) 1.59 V POC 模式 (选项字节: POCMODE = 0)



- 注: 1. 由复位信号产生将 LVIMK 标志设置为"1"。
  - 2. 可以设置 LVIF 标志为(1)。
  - **3.** LVIRF 是复位控制标志寄存器(RESF)的第 0 位。需要了解 RESF 的详细内容,可参见**第二十三章 复** 位功能。

**备注:** 图 25-5 中的<1>  $\sim$  <7>与 **25.4.1 当检测供电电压(VDD)等级时**中"当启动操作时"的描述<1>  $\sim$  <7>相对应。

# 图 25-5 低电压检测电路内部复位信号产生时序 (检测供电电压(Vop)等级)(2/2)

# ★ (2) 2.7 V/1.59 V POC 模式(选项字节: POCMODE = 1)



- 注: 1. 由复位信号产生设置 LVIMK 标志为"1"
  - 2. 可将 LVIF 标志设置为(1)
  - **3.** LVIRF 是复位控制标志寄存器(RESF)的第 0 位。需要了解 RESF 的详细内容,可参见**第二十三章 复** 位功能。

**备注:** 图 25-5 中的<1> ~ <7>与 **25.4.1 (1) 当检测供电电压(Voo)等级时**中"当启动操作时"的描述<1> ~ <7>相 对应。

## (2) 当检测外部输入引脚的输入电压(EXLVI)等级时

- 当启动操作时
  - <1> 屏蔽 LVI 中断 (LVIMK = 1).
  - <2> 设置低电压检测寄存器(LVIM)的第2位(LVISEL)=1(检测外部输入引脚的输入电压(EXLVI)等级)。
  - <3> 设置 LVIM 的第 7 位 (LVION) =1 (允许 LVI 的操作)。
  - <4> 使用软件等待操作稳定时间(10 μs (MAX.)<sup>±</sup>)。
  - <5> 等待直至根据 LVIM 的第 0 位(LVIF)检测到:外部输入引脚的输入电压(EXLVI) ≥ 检测电压(VEXLVI = 1.21 V (TYP.))
  - <6> 设置 LVIM 的第 1 位(LVIMD)=1(当外部输入引脚的输入电压(EXLVI) < 检测电压(VexLvi = 1.21 V (TYP.))时产生内部复位信号)。</p>

图 25-6 显示了由低电压检测电路产生的内部复位信号的时序。该时序图中的标号与上面的<1> ~ <6>对应。

注意事项: 1. 必须执行<1>。当 LVIMK = 0 时,在完成<3>后可能立即会产生中断。,

- 2. 如果在 LVIMD=1 时,外部输入引脚的输入电压(EXLVI) ≥ 检测电压(VEXLVI = 1.21 V (TYP.)),则不会产生内部复位信号。
- 3. 必须保证外部输入引脚的输入电压(EXLVI): EXLVI < VDD
- 当停止操作时 必须执行以下过程之一。
  - 当使用 8 位存储器操作指令:
     00H →LVIM
  - 当使用 1 位存储器操作指令: 先对 LVIMD 清零(0),再对 LVION 清零(0)。

# 图 25-6 低电压检测电路内部复位信号产生时序 (检测外部输入引脚的输入电压(EXLVI)的等级)



- 注: 1. 由复位信号的产生设置 LVIMK 标志为 "1"。
  - 2. 可以设置 LVIF 标志为(1)。
  - **3.** LVIRF 为复位控制标志寄存器(RESF)的第 0 位。如需了解 RESF 的详细信息,可参见**第二十三章 复位** 功能。

**备注:** 图 25-6 中的<1> ~ <6>与 **25.4.1 (2) 当检测外部输入引脚的输入电压(EXLVI)等级时**中"当启动操作时"的描述<1> ~ <6>相对应。

#### 25.4.2 用于中断

## (1) 当检测供电电压(VDD)等级时

- 当启动操作时
  - <1> 屏蔽 LVI 中断 (LVIMK = 1)
  - <2> 将低电压检测寄存器(LVIM)的第2位(LVISEL)清零(0)(检测供电电压(VDD)等级)(默认值)。
  - <3> 使用低电压检测等级选择寄存器(LVIS)的第  $3\sim0$ 位(LVIS3  $\sim$  LVIS0)设置检测电压。
  - <4> 设置 LVIM 的第 7 位 (LVION) =1 (允许 LVI 的操作)。
  - <5> 使用软件等待操作稳定时间(10 μs (MAX.))。
  - <6> 使用 LVIM 的第 0 位 (LVIF),确定"供电电压 (VDD) ≥ 检测电压 (VLVI)"。
  - <7> 将 LVI 的中断请求标志(LVIIF)清零(0)。
  - <8> 释放 LVI 的中断屏蔽标志 (LVIMK)。
  - <9> 将 LVIM 的第 1 位(LVIMD)清零(0)(当供电电压(VDD) < 检测电压(VLVI)时产生中断信号)(默认值)。
  - <10> 执行 EI 指令 (当使用向量中断时)。

图 25-7 显示了由低电压检测电路产生的中断信号的时序。该时序图中的标号与上面的<1> ~ <9>对应。

- 当停止操作时 必须执行以下过程之一。
  - 当使用 8 位存储器操作指令: 00H →LVIM
  - 当使用 1 位存储器操作指令: 对 LVION 清零 (0)

# 图 25-7. 低电压检测电路中断信号产生时序 (检测供电电压(VDD)的等级) (1/2)

# ★ (1) 1.59 V POC 模式(选项字节: POCMODE = 0)



注: 1. 可由复位信号的产生设置 LVIMK 标志为"1"。

2. 产生中断请求信号(INTLVI),且可以设置 LVIF 和 LVIIF 标志为(1)。

**备注:** 图 25-7 中的<1> ~ <9>与 **25.4.2 (1) 当检测供电电压(Vpp)等级时**中"当启动操作时"的描述<1> ~ <9>相 对应。

# 图 25-7 低电压检测电路中断信号产生时序 (检测供电电压(VDD)等级) (2/2)

# (2) 2.7 V/1.59 V POC 模式 (选项: POCMODE = 1)



注: 1. 可由复位信号的产生设置 LVIMK 标志为"1"。

2. 产生中断请求信号(INTLVI),且可以设置 LVIF 和 LVIIF 标志为(1)。

**备注:** 图 25-7 中的<1>  $\sim$  <9>与 **25.4.2 (1) 当检测供电电压(Voo)等级时**中"当启动操作时"的描述<1>  $\sim$  <9>相 对应。

## (2) 当检测外部输入引脚的输入电压(EXLVI)等级时

- 当启动操作时
  - <1> 屏蔽 LVI 中断 (LVIMK = 1)
  - <2> 设置低电压检测寄存器(LVIM)的第2位(LVISEL)=1(检测外部输入引脚的输入电压(EXLVI)等级)。
  - <3> 设置 LVIM 的第 7 位 (LVION) =1 (允许 LVI 的操作)。
  - <4> 使用软件等待操作稳定时间(10 μs (MAX.))。
  - <5> 使用 LVIM 的第 0 位 (LVIF),确定"外部输入引脚的输入电压(EXLVI) ≥ 检测电压(VEXLVI = 1.21 V (TYP.))"。
  - <6> 将 LVI 的中断请求标志(LVIIF)清零(0)。
  - <7> 释放 LVI 的中断屏蔽标志(LVIMK)。
  - <8> 将 LVIM 的第 1 位(LVIMD)清零(0)(当供电电压(VDD) < 检测电压(VLVI)时产生中断信号)(默认值)。</p>
  - <9> 执行 EI 指令 (当使用向量中断时)。

图 25-8 显示了由低电压检测电路产生的中断信号的时序。该时序图中的标号与上面的<1>~<8>对应。

#### 注意事项: 外部输入引脚的输入电压(EXLVI)必须满足以下条件: EXLVI < VDD

- 当停止操作时 必须执行以下过程之一。
  - 当使用 8 位存储器操作指令: 00H →LVIM
  - 当使用 1 位存储器操作指令: 对 LVION 清零 (0)





- 注: 1. 可由复位信号产生设置 LVIMK 标志为"1"。
  - 2. 产生中断请求信号(INTLVI),且可以设置 LVIF 和 LVIIF 标志为(1)。

**备注:** 图 25-8 中的<1>  $\sim$  <8>与 **25.4.2 (1) 当检测供电电压(Voo)等级时**中 "当启动操作时"的描述<1>  $\sim$  <8>相 对应。

## 25.5 低电压检测电路的注意事项

在系统中,如果供电电压(VDD)在接近 LVI 检测电压(VLVI)的一段时间内产生波动,这时根据低电压检测电路的使用情况进行如下操作。

#### (1) 用于复位

系统可能会反复进行复位和释放复位。

在这种情况下,可采用下面的方法(1)任意设置从复位释放到微控制器的启动所经历的时间。

#### (2) 用于中断

可能会频繁产生中断请求。可采用方法(2)中的(b)。

在该系统中可采用如下方法。

<方法>

#### (1) 用于复位

在释放复位信号后,通过软件计数器(使用一个定时器)等待供电电压的波动期,然后对端口初始化(参见**图 25-9**)。

# (2) 用于中断

- (a) 根据低电压检测寄存器(LVIM)的第 0 位(LVIF),在 LVI 中断服务程序中检查 "供电电压 (VDD)  $\geq$  检测电压 (VLVI)" 的情况。将中断请求标志寄存器 0L(IF0L)的第 0 位(LVIIF)清零。
- (b) 在系统中当供电电压接近 LVI 检测电压,供电电压的波动时间很长时,可根据 LVIF 标志检查"供电电压 (V<sub>DD</sub>) ≥检测电压(V<sub>LVI</sub>)"的情况,等待供电电压的波动期,然后将 LVIIF 标志清零。

备注: 如果设置低电压检测寄存器(LVIM)的第2位(LVISEL)为"1",则对上述方法作如下修改。

- 供电电压(VDD) → 外部输入引脚的输入电压(EXLVI)
- 检测电压(VLVI)
   → 检测电压(VEXLVI = 1.21 V<sup>±</sup>)

# 图 25-9 复位释放后软件处理过程示例 (1/2)

•如果供电电压接近 LVI 检测电压,其波动时间≤50 ms。



注: 流程图显示在下页。

# 图 25-9 复位释放后软件处理过程示例(2/2)

# • 检查复位原因



#### 第二十六章 选项字节

#### 26.1 选项字节的功能

★ 78K0/KF2 中闪存的 0080H ~ 0084H 区域为选项字节。当打开电源或从复位状态重启设备时,设备自动参考选项字节,并设置指定的功能。使用该产品时,必须使用选项字节设置以下几项功能。

在自编程期间使用引导交换功能时,将 0080H  $\sim$  0084H 切换到 1080H  $\sim$  1084H。因此,事先将 0080H  $\sim$  0084H 和 1080H  $\sim$  1084H 设置为相同的值。

#### (1) 0080H/1080H

- O 内部低速振荡器的操作
  - 可由软件停止
  - 不能停止
- O 看门狗定时器间隔时间的设置
- O 看门狗定时器计数器的操作
  - 允许计数器的操作
  - 禁止计数器的操作
- O 看门狗定时器窗口打开周期的设置

#### **★** (2) 0081H/1081H

- O 选择 POC 模式
  - 2.7 V/1.59 V POC 模式操作期间 (POCMODE = 1)

上电时该设备处于复位状态,直至供电电压达到 2.7 V (TYP.)。当电压超过 2.7 V (TYP.)时设备从复位状态释放。此后在 2.7 V 不检测 POC,但在 1.59 V (TYP.)检测 POC。

如果上电后当速率低于 0.5 V/ms (MAX.)时供电电压上升到 1.8 V, 建议使用 2.7 V/1.59 V POC 模式。

• 1.59 V POC 模式操作期间 (POCMODE = 0)

上电时该设备处于复位状态,直至供电电压达到 1.59 V (TYP.)。当电压超过 1.59 V (TYP.)时设备从复位状态释放。此后采用与上电时相同的方法在 1.59 V (TYP.)检测 POC。

#### **★** (3) 0084H/1084H

- O 片上调试操作控制
  - 禁止片上调试操作
  - 一旦证明片上调试安全 ID 失效时,允许片上调试操作和擦除闪存数据。
  - 一旦证明片上调试安全 ID 失效时,允许片上调试操作,但不擦除闪存数据。
- 注意事项: 1. 对于没有配备片上调试功能的产品(µPD78F0544, 78F0545, 78F0546 和 78F0547), 必须将 00H 赋 给 0084H 单元(禁止片上调试操作)。由于在引导交换时 0084H 和 1084H 要相互切换,因此也要对 1084H 设置 00H。
  - 2. 对于具有片上调试功能的产品(μPD78F0547D),如果要使用它的片上调试功能,需要对 0084H 单元 赋值 02H 或 03H。由于在引导交换时 0084H 和 1084H 要相互切换,因此也要对 1084H 设置与 0084H 相同的值。
- ★ 注意事项: 必须对 0082H 和 0083H(当使用引导交换功能时为 0082H/1082H 和 0083H/1083H) 设置 00H。

### 26.2 选项字节的格式

选项字节格式如下。

### 图 26-1 选项字节的格式 (1/2)

地址: 0080H/1080H <sup>推</sup>

| <br>7 | 6       | 5       | 4     | 3     | 2     | 1     | 0      |
|-------|---------|---------|-------|-------|-------|-------|--------|
| 0     | WINDOW1 | WINDOW0 | WDTON | WDCS2 | WDCS1 | WDCS0 | LSROSC |

| WINDOW1 | WINDOW0 | 看门狗定时器窗口打开周期 |
|---------|---------|--------------|
| 0       | 0       | 25%          |
| 0       | 1       | 50%          |
| 1       | 0       | 75%          |
| 1       | 1       | 100%         |

| WDTON | 看门狗定时器计数器的操作控制/非法访问检测        |  |  |  |  |  |
|-------|------------------------------|--|--|--|--|--|
| 0     | 禁止计数器操作 (复位后停止计数),禁止非法访问检测操作 |  |  |  |  |  |
| 1     | 允许计数器操作 (复位后开始计数),允许非法访问检测操作 |  |  |  |  |  |

| WDCS2 | WDCS1 | WDCS0 | 看门狗定时器溢出时间                                   |  |  |  |
|-------|-------|-------|----------------------------------------------|--|--|--|
| 0     | 0     | 0     | 2 <sup>10</sup> /f <sub>RL</sub> (3.88 ms)   |  |  |  |
| 0     | 0     | 1     | 2 <sup>11</sup> /f <sub>RL</sub> (7.76 ms)   |  |  |  |
| 0     | 1     | 0     | 2 <sup>12</sup> /f <sub>RL</sub> (15.52 ms)  |  |  |  |
| 0     | 1     | 1     | 2 <sup>13</sup> /f <sub>RL</sub> (31.03 ms)  |  |  |  |
| 1     | 0     | 0     | 2 <sup>14</sup> /f <sub>RL</sub> (62.06 ms)  |  |  |  |
| 1     | 0     | 1     | 2 <sup>15</sup> /f <sub>RL</sub> (124.12 ms) |  |  |  |
| 1     | 1     | 0     | 2 <sup>16</sup> /f <sub>RL</sub> (248.24 ms) |  |  |  |
| 1     | 1     | 1     | 2 <sup>17</sup> /f <sub>RL</sub> (496.48 ms) |  |  |  |

|   | LSROSC | 内部低速振荡器操作                                    |
|---|--------|----------------------------------------------|
|   | 0      | 可由软件停止 (当将 1 写入 RCM 寄存器的第 0 位(LSRSTOP)时停止操作) |
| Ī | 1      | 不能停止 (即使将 1 写入 LSRSTOP 位也不停止操作)              |

★ 注: 由于在引导交换时 0080H 和 1080H 要相互切换,因此要对 0080H 设置与 1080H 相同的值。

### 注意事项: 1. 禁止设置: WDCS2 = WDCS1 = WDCS0 = 0 且 WINDOW1 = WINDOW0 = 0

- 2. 闪存自编程和 EEPROM 仿真期间不要停止看门狗定时器。处理过程中中断响应时间将被延迟。设置 溢出时间和窗口大小时应考虑到这一延迟情况。
- 3. 如果 LSROSC = 0(可由软件停止振荡),则无论内部振荡模式寄存器(RCM)的第 0 位(LSRSTOP)为何值,在 HALT 和 STOP 模式下对看门狗定时器不提供计数时钟。

当 8 位定时器 H1 使用内部低速振荡时钟时,即使在 HALT/STOP 模式下也对 8 位定时器 H1 提供计数时钟。

4. 必须对第7位清零(0)。

**备注:** 1. frL: 内部低速振荡时钟频率

**2.** ():  $f_{RL} = 264 \text{ kHz (MAX.)}$ 

### 图 26-1 选项字节的格式 (2/2)

★ 地址: 0081H/1081H <sup>注 1, 2</sup>

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|---|---|---|---|---|---|---|---------|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | POCMODE |

| POCMODE | POC 模式选择            |
|---------|---------------------|
| 0       | 1.59 V POC 模式 (默认)  |
| 1       | 2.7 V/1.59 V POC 模式 |

- 注: 1. 使用专用闪存编程器只能对 POCMODE 进行写操作。在自编程期间不能设置 POCMODE,或者自编程 引导交换(此时,设置 1.59 V POC 模式(默认))操作时也不能设置。但由于引导交换时 1081H 单元的值 被复制到 0081H 单元,建议在使用引导交换功能时为 1081H 单元设置与 0081H 相同的值。
  - **2.** 要改变 POC 模式的设置,可在对闪存进行一次性擦除(片擦除)后将该值再次写入 0081H 中。在对闪存指定存储块擦除后不能修改设置。

# 注意事项: 必须将第 7 $\sim$ 1 位清零(0)。

★ 地址: 0082H/1082H, 0083H/1083H <sup>推</sup>

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**注:** 由于 0082H 与 0083H 单元为保留区域,因此必须对这两个存储单元赋值 00H。由于在引导交换时 0082H 与 0083H 要和 1082H 与 1083H 相互切换,因此也要对 1082 与 1083H 设置 00H。

★ 地址: 0084H/1084H <sup>往1, 2</sup>

| 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0      |
|---|---|---|---|---|---|--------|--------|
| 0 | 0 | 0 | 0 | 0 | 0 | OCDEN1 | OCDEN0 |

| OCDEN1 | OCDEN0 | 片上调试操作控制                       |
|--------|--------|--------------------------------|
| 0      | 0      | 禁止操作                           |
| 0      | 1      | 禁止设置                           |
| 1      | 0      | 允许操作。在确定片上调试安全 ID 失效时不要擦除闪存数据。 |
| 1      | 1      | 允许操作。在确定片上调试安全 ID 失效时可以擦除闪存数据。 |

- **注:** 1. 对于没有配备片上调试功能的产品(μPD78F0544, 78F0545, 78F0546 和 78F0547), 必须将 00H 赋给 0084H 单元(禁止片上调试操作)。由于在引导交换时 0084H 和 1084H 要相互切换, 因此也要对 1084H 设置 00H。
  - 2. 对于具有片上调试功能的产品(μPD78F0547D),如果要使用它的片上调试功能,需要对 0084H 单元赋值 02H 或 03H。由于在引导交换时 0084H 和 1084H 要相互切换,因此也要对 1084H 设置与 0084H 相同的值。

备注: 如需了解片上调试安全 ID 的详细信息,参见第二十八章 片上调试功能 (仅用于μPD78F0547D)。

★ 以下是设置选项字节的软件描述示例

OPT CSEG AT 0080H OPTION: DB 30H ;允许看门狗定时器的操作(对非法访问检测的操作), ;看门狗定时器窗口打开周期:50%, ;看门狗定时器的溢出时间: 210/fRL, ;可由软件停止内部低速振荡器 DB 00H ; 1.59 V POC 模式 00H DB ;保留区域 DB 00H ;保留区域 DB 00H ;禁止片上调试

**备注:** 复位处理期间参考选项字节。如需了解复位处理的时序,可参见**第二十三章 复位功能**。

### 第二十七章 闪存

78K0/KF2 包含闪存,可以安装在电路板上实现在线写入、擦除和覆盖操作。

### 27.1 内部存储器容量切换寄存器

可以使用内部存储器容量切换寄存器(IMS)选择内存容量。 可使用 8 位存储器操作指令设置 IMS。 复位信号的产生将 IMS 设置为 CFH。

注意事项: 复位释放后必须按照表 27-1 对每个产品进行设置。

图 27-1. 内部存储器容量切换寄存器 (IMS) 的格式

 地址: FFF0H
 复位后: CFH
 R/W

 符号
 7
 6
 5
 4
 3
 2
 1
 0

 IMS
 RAM2
 RAM1
 RAM0
 0
 ROM3
 ROM2
 ROM1
 ROM0

| RAM2 | RAM1 | RAM0 | 内部高速 RAM 容量选择 |  |  |  |
|------|------|------|---------------|--|--|--|
| 1    | 1    | 0    | 1024 字节       |  |  |  |
| 其 它  |      |      | 禁止设置          |  |  |  |

| ROM3 | ROM2 | ROM1 | ROM0 | 内部 ROM 容量选择 |
|------|------|------|------|-------------|
| 1    | 1    | 0    | 0    | 48 KB       |
| 1    | 1    | 1    | 1    | 60 KB       |
|      | 其    | 它    |      | 禁止设置        |

★ 注意事项:如果要设置存储器容量,应先设置 IMS 再设置 IXS。设置存储器容量时应使内存 ROM 和内部扩展 RAM 区域不要产生重叠。

表 27-1. 内部存储器容量切换寄存器的设置

| 闪存版本 (78K0/KF2)      | IMS 设置           |
|----------------------|------------------|
| μPD78F0544           | ССН              |
| µРD78F0545           | CFH              |
| µРD78F0546           | CCH <sup>±</sup> |
| µРD78F0547, 78F0547D | CCH <sup>±</sup> |

注: μPD78F0546、μPD78F0547 和 78F0547D 分别有 96 KB 和 128 KB 的内部 ROM。但是由于使用了存储器组,这些设备中 IMS 的设置值与 48 KB 产品的相同。如需了解存储器组的设置方法,可参见**图 4-2 存储器组选择寄存器(BANK)的格式**。

### 27.2 内部扩展 RAM 容量切换寄存器

使用内部扩展 RAM 容量切换寄存器(IXS)可以选择内部扩展 RAM 的容量。可使用 8 位存储器操作指令设置该寄存器。 复位信号的产生将 IXS 设置为 0CH。

注意事项: 在复位释放后必须如表 27-2 所示设置每种产品的值。

图 27-2. 内部扩展 RAM 容量切换寄存器 (IXS) 的格式

地址: FFF4H 复位后: 0CH R/W 符号 7 4 3 2 1 0 5 IXRAM0 IXS 0 0 0 IXRAM4 IXRAM3 IXRAM2 IXRAM1

| IXRAM4 | IXRAM3 | IXRAM2 | IXRAM1 | IXRAM0 | 内部扩展 RAM 容量选择 |
|--------|--------|--------|--------|--------|---------------|
| 0      | 1      | 0      | 1      | 0      | 1024 字节       |
| 0      | 1      | 0      | 0      | 0      | 2048 字节       |
| 0      | 0      | 1      | 0      | 0      | 4096 字节       |
| 0      | 0      | 0      | 0      | 0      | 6144 字节       |
|        |        | 其 它    |        |        | 禁止设置          |

★ 注意事项: 如果要设置存储器容量,应先设置 IMS,再设置 IXS。设置存储器容量时应使内存 ROM 和内部扩展 RAM 区域不要产生重叠。

表 27-2. 内部扩展 RAM 容量切换寄存器 (IXS) 的设置

| 1400年日 1400年日 1400日  W = = 11 Hr / /C = = = 1 |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--|--|--|--|--|
| 闪存版本 (78K0/KF2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | IXS 设置                   |  |  |  |  |  |
| μPD78F0544                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0AH                      |  |  |  |  |  |
| μPD78F0545                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 08H                      |  |  |  |  |  |
| μPD78F0546                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 04H                      |  |  |  |  |  |
| μPD78F0547, 78F0547D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 00H                      |  |  |  |  |  |

### 27.3 用闪存编程器写入数据

可使用专用闪存编程器将数据写入闪存,可以在线写入,也可以离线写入。

# (1) 在线编程

当目标系统上安装了 78K0/KF2 系列产品后,闪存的内容可以被重写。必须将连接专用闪存编程器的连接器安装在目标系统中。

#### (2) 离线编程

在将 78K0/KF2 系列产品安装到目标系统之前,可使用专用程序适配器(FA 系列)将数据写入闪存。

**备注:** FA 系列是 Naito Densei Machida Mfg. Co., Ltd.的产品。

表 27-3. 78K0/KF2 系列产品与专用闪存编程器之间的写操作

| 专用闪存编程器的引脚配置    |     | 使用 CSI1      | 使用 CSI10         |           | 使用 UART6          |      |
|-----------------|-----|--------------|------------------|-----------|-------------------|------|
| 信号名称            | I/O | 引脚功能         | 引脚名称             | 引脚名称 引脚编号 |                   | 引脚编号 |
| SI/RxD          | 输入  | 接收信号         | SO10/P12         | 52        | TxD6/P13          | 51   |
| SO/TxD          | 输出  | 发送信号         | SI10/RxD0/P11    | 53        | RxD6/P14          | 50   |
| SCK             | 输出  | 传送时钟         | SCK10/TxD0/P10   | 54        | -                 | _    |
| CLK             | 输出  | 78K0/KF2 的时钟 | _推1              | _         | EXCLK/X2/P122 **2 | 14   |
|                 |     |              |                  |           |                   |      |
| /RESET          | 输出  | 复位信号         | RESET            | 10        | RESET             | 10   |
| FLMD0           | 输出  | 模式信号         | FLMD0            | 13        | FLMD0             | 13   |
| V <sub>DD</sub> | I/O | VDD 电压产生/    | V <sub>DD</sub>  | 19        | V <sub>DD</sub>   | 19   |
|                 |     | 电压监测         | EV <sub>DD</sub> | 20        | EV <sub>DD</sub>  | 20   |
|                 |     |              | AVREF            | 59        | AVREF             | 59   |
| GND             | _   | 地            | Vss              | 17        | Vss               | 17   |
|                 |     |              | EVss             | 18        | EVss              | 18   |
|                 |     |              | AVss             | 60        | AVss              | 60   |

- 注: 1. 在使用 CSI10 时,只能使用内部高速振荡时钟 (fRH)。
  - 2. 在使用 UART6 时,只能使用 X1 时钟 (fx) 或外部主系统时钟 (fexclk)。若要使用闪存编程器的时钟,则应将编程器的 CLK 与 EXCLK 相连。

在使用适配器对闪存进行写操作时可采用如下所示的连接方式。

# 图 27-3. 3 线串行 I/O (CSI10) 模式下使用适配器对闪存进行写操作示例



# 图 27-4. UART (UART6) 模式下使用适配器对闪存进行写操作示例



### 27.4 编程环境

以下是 78K0/KF2 闪存所需的编程环境。

图 27-5. 闪存编程环境



需要有一个控制专用闪存编程器的主机。

专用闪存编程器与 78KO/KF2 的接口使用 CSI10 或 UART6 进行写和擦除等操作。闪存离线写操作时必须使用一个专用程序适配器(FA 系列)。

# 27.5 通信模式

通过 78K0/KF2 的 CSI10 或 UART6,在专用闪存编程器与 78K0/KF2 之间建立串行通信。

## (1) CSI10

★ 传送速率: 2.4 kHz ~ 2.5 MHz

图 27-6. 专用闪存编程器的通信 (CSI10)



#### (2) UART6

传送速率: 115200 bps

图 27-7. 专用闪存编程器的通信(UART6)



如果 FlashPro4 用作专用闪存编程器,它将为 78K0/KF2 提供如下信号。如需了解详细内容,可参阅 FlashPro4 手册。

表 27-4. 引脚连接

|           |     | *** *********************************** |                  |                  |                  |
|-----------|-----|-----------------------------------------|------------------|------------------|------------------|
| FlashPro4 |     | 78K0/KF2                                | 连                | 接                |                  |
| 信号名称      | I/O | 引脚功能                                    | 引脚名称             | CSI10            | UART6            |
| FLMD0     | 输出  | 模式信号                                    | FLMD0            | 0                | 0                |
| $V_{DD}$  | I/O | VDD 电压产生/电源监测                           | VDD, EVDD, AVREF | 0                | 0                |
| GND       | _   | 地                                       | Vss, EVss, AVss  | 0                | 0                |
| CLK       | 输出  | 输出到 78K0/KF2 的时钟                        | EXCLK            | × <sup>推 1</sup> | 〇 <sup>往 2</sup> |
| /RESET    | 输出  | 复位信号                                    | RESET            | 0                | 0                |
| SI/RxD    | 输入  | 接收信号                                    | SO10/TxD6        | 0                | 0                |
| SO/TxD    | 输出  | 发送信号                                    | SI10/RxD6        | 0                | 0                |
| SCK       | 输出  | 传送时钟                                    | SCK10            | 0                | ×                |

- 注: 1. 在使用 CSI10 时,只能使用内部高速振荡时钟 (fRH)。
  - **2.** 在使用 UART6 时,只能使用 X1 时钟 (fx)或外部主系统时钟 (fexclk)。若要使用闪存编程器的时钟,则应将编程器的 CLK 与 EXCLK 相连。
- 备注: ◎: 必须连接该引脚。
  - O: 如果信号由目标板产生,则不要连接该引脚。
  - x: 不要连接该引脚

### 27.6 在线方式的引脚连接

对闪存进行在线写操作时,目标系统必须有连接专用闪存编程器的连接器。电路板上首先要提供一个选择功能,可以选择正常操作模式或闪存编程模式。

当设置闪存编程模式时,那些不用于闪存编程的引脚状态与复位后的状态相同。因此如果外部设备不能立即识别复位后的状态,则必须采用如下方式连接引脚。

#### 27.6.1 FLMD0 引脚

在普通操作模式下,FLMD0 引脚的输入电压为 0V。在闪存编程模式中,将 VDD 写电压提供给 FLMD0 引脚。FLMD0 引脚的连接示意图如下所示。

图 27-8. FLMD0 引脚连接示例



### 27.6.2 串行接口引脚

串行接口使用的引脚如下所示。

表 27-5. 串行接口使用的引脚

| 串行接口  | 使用的引脚             |  |
|-------|-------------------|--|
| CSI10 | SO10, SI10, SCK10 |  |
| UART6 | TxD6, RxD6        |  |

在将专用闪存编程器和串行接口 (已与板上其它设备连接) 的引脚相连时,必须特别注意:信号之间不能冲突,并且另一个设备不能出现误动作。

### (1) 信号冲突

如果专用闪存编程器 (输出端)与串行接口 (已连接到另一个设备的输出端)的一个输入引脚相连,这时会产生信号冲突。为了避免这种情况,应隔离与另一个设备的连接,或者使另一个设备处于高阻抗状态。

图 27-9. 信号冲突 (串行接口的输入引脚)



在闪存编程模式下,设备的输出信号与专用闪存编程器发送的信号发生冲突。因此必须隔离该设备的信号。

## (2) 其它设备的故障

如果专用闪存编程器的输出或输入端与串行接口(已连接到另一个设备的输入端)的一个输入或输出引脚相连,则信号可能会输出到另一个设备,从而引起该设备的故障。为了避免这种情况,应隔离与该设备的连接。

#### 图 27-10 其它设备的故障



在闪存编程模式下,如果 78K0/KF2 的输出信号影响到其它设备,则 必须隔离该设备的信号。



在闪存编程模式下,如果专用闪存编程器的输出信号影响到其它设备,则必须隔离该设备的信号。

#### 27.6.3 RESET 引脚

如果将专用闪存编程器的复位信号连接到 RESET 引脚(已连接到板上的复位信号发生器),则会产生信号冲突。为了避免这种情况,应隔离与复位信号发生器的连接。

在闪存编程模式下,如果从用户系统输入复位信号,则不能对闪存进行正确编程。因此除了专用闪存编程器的复位信号外,不要输入其它信号。

图 27-11 信号冲突 (RESET 引脚)



在闪存编程模式中,复位信号发生器输出的信号与专用闪存编程器的输出信号发生冲突。因此必须隔离复位信号发生器的信号。

#### 27.6.4 端口引脚

当设置闪存编程模式时,那些不用于闪存编程的引脚状态与复位后的状态相同。因此,如果外部设备(与端口相连)不能立即识别复位后的状态,则必须通过一个电阻将端口引脚连接到 VDD 或 VSS。

### 27.6.5 REGC 引脚

按照与正常操作模式下相同的方法,通过一个电容(0.47 μF: 目标)连接 REGC 引脚到 GND。

#### 27.6.6 其它信号引脚

使用在线时钟时,以与正常操作模式下相同的状态连接 X1 和 X2。 但如果从编程器输入操作时钟,则将编程器的时钟输出连接到 EXCLK。

注意事项: 1. 在使用 CSI10 时,只能使用内部高速振荡时钟 (frн)。

2. 在使用 UART6 时,只能使用 X1 时钟 (fx)或外部主系统时钟 (fexclk)。

### 27.6.7 供电电压

如果使用闪存编程器输出的供电电压,则将 VDD 引脚与闪存编程器的 VDD 相连,将 Vss 引脚与闪存编程器的信号地相连。

然而,如果要使用闪存编程器的电压监视功能,必须将 $V_{DD}$ 和 $V_{SS}$ 引脚分别与闪存编程器的 $V_{DD}$ 和GND相连。如果使用电路板上的供电电压,则按照正常操作模式中的连接方式进行连接。

要使用在线供电电压,连接方式应与正常操作模式一致。

其它的供电电压(EVDD、EVss、AVREF、和 AVss)与正常操作模式中的相同。

## 27.7 编程方法

### 27.7.1 控制闪存

下图显示了闪存操作过程。

图 27-12. 闪存操作过程



### 27.7.2 闪存编程模式

如果通过专用闪存编程器重写闪存的内容,则必须将 78K0/KF2 设置为闪存编程模式。而要设置该模式,必须将 FLMD0 引脚连接到 VDD,并对复位信号清零。

当在线写闪存时,使用跳线改变模式。

图 27-13. 闪存编程模式



表 27-6. FLMD0 引脚与复位释放后操作模式之间的关系

| FLMD0           | 操作模式   |  |  |
|-----------------|--------|--|--|
| 0               | 正常操作模式 |  |  |
| V <sub>DD</sub> | 闪存编程模式 |  |  |

### 27.7.3 选择通信模式

在 78K0/KF2 中,进入专用闪存编程模式后,通过将脉冲(可多达 11 个脉冲)输入到 FLMD0 引脚,来选择通信模式。由闪存编程器产生这些 FLMD0 脉冲。

下表显示了脉冲个数与通信模式之间的关系。

#### 表 27-7. 通信模式

| THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PART OF THE PA |                        |                 |    |                     |       |             |        |     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------|----|---------------------|-------|-------------|--------|-----|
| 通信模式                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 标准设置 <sup>&amp;1</sup> |                 |    |                     | 使用的引脚 | 外部时钟        | FLMD0  |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 端口                     | 速率              | 目标 | 频率                  | 倍率    |             |        | 脉冲数 |
| UART                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | UART-ch0               | 115200 bps ** 3 | 可选 | 1 ~ 20              | 1.0   | TxD6, RxD6  | fx     | 0   |
| (UART6)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |                 |    | MHz <sup>2± 2</sup> |       |             | fexclk | 3   |
| 3 线串行 I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | SIO-ch0                | 2.4 kHz $\sim$  |    |                     |       | SO10, SI10, | fкн    | 8   |
| (CSI10)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        | 2.5 MHz         |    |                     |       | SCK10       |        |     |

## 注: **1.** FlashPro4 标准设置选项

- 2. 电压不同设置范围也不一样。如需了解详细内容,可参见电子产品规范章节。
- **3.** 波特率误差以外的因素,如信号波形瞬变,也会影响 UART 通信,因此必须象测量波特率误差一样严格测量 瞬变。

注意事项: 当选择 UART6 时,在接收到 FLMD0 脉冲后,根据专用闪存编程器发送的复位命令计算接收时钟。

**备注:** fx: X1 时钟

 fexclk:
 外部主系统时钟

 frh:
 内部高速振荡时钟

## 27.7.4 通信命令

78K0/KF2 使用命令与专用闪存编程器进行通信。从闪存编程器发往 78K0/KF2 的信号称为命令,从 78K0/KF2 发往 专用闪存编程器的命令称为响应命令。

## 图 27-14. 通信命令



专用闪存编程器

78K0/KF2的闪存控制命令列表如下。所有这些命令都从编程器发出,78K0/KF2根据相应的命令进行处理。

### 表 27-8. 闪存控制命令

| 类别      | <b>令名称</b> 功能 |                                     |
|---------|---------------|-------------------------------------|
| 校验      | 一次性校验命令       | 将输入数据与全部存储器内容进行比较                   |
| 擦除      | 一次性擦除命令       | 擦除全部存储器内容                           |
| 空白检测    | 一次性空白检测命令     | 检查全部存储器的擦除状态                        |
| 数据写     | 高速写命令         | 根据写操作地址和被写的字节数写入数据,并进<br>行校验。       |
|         | 连续写命令         | 从前面刚刚执行的高速写命令的下一条地址开始<br>写数据,并进行校验。 |
| 系统设置、控制 | 状态读命令         | 获取操作状态                              |
|         | 振荡频率设置命令      | 设置振荡频率                              |
|         | 擦除时间设置命令      | 设置用于一次性擦除的擦除时间                      |
|         | 写时间设置命令       | 设置用于写数据的写操作时间                       |
|         | 波特率设置命令       | 当使用 UART 时设置波特率                     |
|         | 硅标记命令         | 读取硅标记信息                             |
|         | 复位命令          | 状态转换                                |

78K0/KF2 根据专用闪存编程器发出的命令返回一个响应命令。78K0/KF2 发出的响应命令列表如下。

表 27-9. 响应命令

| 命令名称 | 功能        |  |
|------|-----------|--|
| ACK  | 响应命令/数据   |  |
| NAK  | 响应非法命令/数据 |  |

### ★ 27.8 安全性设置

使用安全性设置命令可以执行如下操作。在设置下一个编程模式时,安全性设置有效。

• 禁止一次性擦除 (片擦除)

该项设置禁止对闪存所有块进行块擦除和一次性擦除(片擦除)。一旦禁止执行一次性擦除命令,所有禁止设置项不能被取消。

注意事项:在对一次性擦除进行安全性设置后,不能再对该设置执行擦除操作。此外,由于禁止执行擦除命令,即 使执行了写命令,与已经写到闪存中的数据不同的数据也不能被写入。

• 禁止块擦除

该项设置禁止对闪存中的指定区域进行块擦除。使用一次性擦除(片擦除)命令可以取消该项设置。

• 禁止写

该项设置禁止对闪存所有块进行写和块擦除。使用一次性擦除(片擦除)命令可以取消该项设置。

禁止重写引导簇 0

该项设置禁止对闪存中引导簇 0(0000H ~ 0FFFH)进行一次性擦除(片擦除)、块擦除和写操作。

注意事项: 如果对重写引导簇 0 进行了安全性设置,则不能再对该设备的引导簇 0 进行重写。

闪存在默认设置下,允许使用一次性擦除(片擦除)、块擦除、写和重写引导簇 0 命令。以上安全性设置仅用于在线/ 离线编程。各项安全性设置可以结合使用。

表 27-10 显示了当允许使用 78K0/KF2 安全性功能时擦除命令与写命令之间的关系。

表 27-10. 当允许使用安全性功能时命令之间的关系

| 安全性设置        | 一次性擦除(片擦除)<br>命令 | 块擦除命令 | 写命令             |
|--------------|------------------|-------|-----------------|
| 禁止一次性擦除(片擦除) | 无效               | 无效    | 有效 <sup>性</sup> |
| 禁止块擦除        | 有效               |       | 有效              |
| 禁止写          |                  |       | 无效              |
| 禁止重写引导簇 0    | 无效               |       |                 |

注: 由于禁止使用擦除命令,所以与已经写到闪存中的数据不同的数据不能被写入。

表 27-11 显示了安全性设置与每种编程模式下操作之间的关系。

表 27-11. 安全性设置于每种编程模式下操作之间的关系

| 编程模式         | 在线/离线编程 |                  | 自编程   |                  |
|--------------|---------|------------------|-------|------------------|
| 安全性设置        | 安全性设置   | 安全性操作            | 安全性设置 | 安全性操作            |
| 禁止一次性擦除(片擦除) | 允许      | 有效 <sup>±1</sup> | 禁止    | 无效 <sup>往2</sup> |
| 禁止块擦除        |         |                  |       |                  |
| 禁止写          |         |                  |       |                  |
| 禁止重写引导簇 0    |         |                  | 允许    | 有效               |

### 注: 1. 通过安全性设置可以禁止每种命令的执行。

2. 无论是否进行安全性设置,都允许执行自编程命令。

#### 27.9 通过自编程进行闪存编程

78K0/KF2 支持自编程功能,即可以通过用户程序重写闪存。由于该功能允许用户应用程序使用 78K0/KF2 自编程库 重写闪存,因此可用于对程序升级。

如果自编程期间产生中断,可以暂时停止自编程操作,而去执行中断服务程序。要执行中断服务程序,应在停止自编程操作后恢复正常操作模式,并执行 EI 指令。而在恢复自编程模式后,可以恢复自编程操作。

**备注:** 如需了解自编程功能和 78K0/KF2 自编程库的详细信息,可参见即将发行的单独的文档 (文档名称: 78K0/Kx2 应用指南,发行时间: 未定)。

### 注意事项: 1. 当 CPU 使用子系统时钟时不能使用自编程功能。

- 2. 自编程期间 FLMD0 引脚应输入高电平。
- 3. 在启动自编程之前必须执行 DI 指令。 自编程功能检查中断请求标志 (IFOL, IFOH, IF1L 和 IF1H)。如果产生了中断请求,则停止自编程操作。
- 4. 即使在 DI 状态下也可以通过未屏蔽的中断请求停止自编程。要避免这种情况,可以通过使用中断屏 蔽标志寄存器(MK0L, MK0H, MK1L 和 MK1H)屏蔽该中断。
- 5. 执行自编程操作时使用内部高速振荡时钟。如果 CPU 使用 X1 时钟或外部主系统时钟,则在自编程期间要经历内部高速振荡时钟的振荡稳定等待时间。
- 6. 将用于自编程的入口程序分配在共享区域(0000H ~ 7FFFH)。



图 27-15. 用于自编程的操作模式与存储器映射 (µPD78F0547)

自编程过程显示如下。

图 27-16. 自编程过程



#### ★ 27.9.1 引导交换功能

如果在自编程期间由于电源失效或其它原因导致重写引导区域的操作失败,则引导区域的数据可能会丢失且不能通过复位重启程序。

使用引导交换功能可以避免这种情况。

在擦除引导簇 0(这是一个引导程序区域)<sup>±</sup>之前,先通过自编程将一个新的引导程序写入引导簇 1。当将该程序正确写入引导簇 1后,通过使用 78K0/KF2 固件的设置信息功能将引导簇 1与引导簇 0的内容交换,这样引导簇 1就用作引导区域。之后对初始引导程序区域,即引导簇 0进行擦除或写操作。

这样,即使在重写引导程序区域时出现电源失效,也能够正确执行程序,这是因为程序在复位并再次执行时实行了 从引导簇1的引导交换。

如果已经将程序正确写入引导簇 0,则通过使用 78K0/KF2 固件的设置信息功能恢复初始引导区域。

注: 一个引导簇的容量为 4 KB,通过引导交换功能交换引导簇 0 与引导簇 1 的内容。

引导簇 0 (0000H  $\sim$  0FFFH): 初始引导程序区域 引导簇 1 (1000H  $\sim$  1FFFH): 用于引导交换的区域

图 27-17. 引导交换功能



### 图 27-18. 引导交换执行示例



\*

μPD78F0547D 使用 V<sub>DD</sub>、FLMD0、RESET、OCD0A/X1 (或 OCD1A/P31)、OCD0B/X2 (或 OCD1B/P32),和 Vss 引脚,通过片上调试仿真器(QB-78K0MINI)与主机通信,进行片上调试。可以选择 OCD0A/X1 与 OCD1A/P31 或 OCD0B/X2 与 OCD1B/P32。

注意事项: μPD78F0547D 具有片上调试功能。由于在使用片上调试功能后产品的稳定性不能得到保证,因此在给定 闪存可重写次数的情况下不要将该产品用于大规模生产。NEC Electronics 不接受有关该产品的投诉。



图 28-1 QB-78K0MINI 与 \$\mu\$PD78F0547D 的连接示例 (当使用 OCD0A/X1 和 OCD0B/X2 时)

注: 下拉电阻值至少应为 470  $\Omega$ 。

注意事项: 1. 在片上调试期间从 OCD0A/X1 引脚输入时钟。

2. 通过外部下拉 OCD1A/P31 引脚或通过使用 P130 引脚的外部电路(当该设备复位时输出低电平), 控制 OCD0A/X1 和 OCD0B/X2 引脚。



图 28-2 QB-78K0MINI 与 PD78F0547D 连接示例 (当使用 OCD1A 和 OCD1B 时)

注: 下拉电阻值至少应为  $470 \Omega$ 。

地址

## 28.1 片上调试安全 ID

在μPD78F0547D中,一个片上调试操作控制标志存放在闪存地址 0084H中 (参见**第二十六章 可选字节**),片上调试 安全 ID 设置在地址 0085H  $\sim$  008EH 中。

当使用引导交换功能时,由于 0084H、0085H ~ 008EH 与 1084H 以及 1085H ~ 108EH 的内容被交换,因此预先 设置与 1084H 以及 1085H ~ 108EH 的内容相同的值。

如需了解片上调试安全 ID 的详细内容,可参见 QB-78K0MINI 用户手册 (U17029E)。

片上调试安全 ID  $0085H\sim008EH$ 10字节的 ID 代码  $1085H \sim 108EH$ 

表 28-1 片上调试安全 ID

### 第二十九章 指令集

本章以表格方式列出了 78K0/KF2 的指令集。如需了解每种指令的操作和操作代码,可参阅 **78K/0 系列指令用户手册** (**U12326E**)。

#### 29.1 操作列表使用规则

#### 29.1.1 操作数标识符和标识方法

根据规范确定的指令操作数标识方法(详情可参见汇编程序编程规范),在每种指令的"操作数"栏列出操作数。如果有两种或两种以上的标识方法,可选其中之一。大写字母和符号#、!、\$和[]是关键字,必须按其原样书写。每种符号的含义如下所示。

- #: 立即数标识
- !: 绝对地址标识
- \$: 相对地址标识
- []: 间接地址标识

立即数用来描述一个数值型数据或标号。当使用标号时,注意必须加上符号#,!,\$,和[]。

对应操作数寄存器标识符 r 和 rp,功能名称 (X, A, C, 等)或绝对名称 (下表括号中的名称: R0, R1, R2 等)都可用于标识。

表 29-1 操作数标识符和标识方法

标识符 标识方法

X (R0), A (R1), C (R2), B (R3), E (R4), D (R5), L (R6), H (R7)

AX (RP0), BC (RP1), DE (RP2), HL (RP3)

#### rp 特殊功能寄存器符号<sup>建</sup> sfr 特殊功能寄存器符号 (仅用于 16 位可操作寄存器偶地址) \*\* sfrp FE20H~FF1FH 立即数或标号 saddr $FE20H \sim FF1FH$ 立即数或标号 (仅用于偶地址) saddrp addr16 0000H~FFFFH立即数或标号 (仅用于16位数据传送指令的偶地址) addr11 0800H ~ 0FFFH 立即数或标号 addr5 0040H ~ 007FH 立即数或标号 (仅用于偶地址) word 16 位立即数或标号 byte 8位立即数或标号

注: 不能使用这些操作数访问地址 FFD0H ~ FFDFH。

3位立即数或标号

RB0~RB3

**备注:** 特殊功能寄存器符号参见表 3-6 特殊功能寄存器列表

bit RBn

### 29.1.2 操作栏描述

A: A 寄存器; 8 位累加器

X: X 寄存器

B: B 寄存器

C: C 寄存器

D: D 寄存器

E: E 寄存器

H: H 寄存器

L: L 寄存器

AX: AX 寄存器对; 16 位累加器

BC: BC 寄存器对

DE: DE 寄存器对

HL: HL 寄存器对

PC: 程序计数器

SP: 堆栈指针

PSW: 程序状态字

CY: 进位标志

AC: 辅助进位标志

Z: 零标志

RBS: 寄存器组选择标志

IE: 中断请求允许标志

(): 括号中的地址或寄存器所指的存储单元的内容

X<sub>H</sub>, X<sub>L</sub>: 16 位寄存器的高 8 位和低 8 位

A: 逻辑与 (AND)

v: 逻辑或 (OR)

→: 逻辑异或 (exclusive OR)

—: 数据取反

addr16: 16位立即数或标号

jdisp8: 带符号的 8 位数据(偏移量)

### 29.1.3 标志操作栏的描述

(空): 不受影响

0: 清零

1: 设置为1

×: 根据结果进行设置/清零

R: 恢复先前保存的值

# 29.2 操作列表

| 14. A At | 山口佐 | 10 /l- wl.          | 字节 | I  | 时钟  | 42 //-                          | 7 | 标志    |
|----------|-----|---------------------|----|----|-----|---------------------------------|---|-------|
| 指令组      | 助记符 | 操作数                 | 数  | 注1 | 注 2 | 操作                              | Z | AC CY |
| 8位数据传    | MOV | r, #byte            | 2  | 4  | =   | r ← byte                        |   |       |
| 送        |     | saddr, #byte        | 3  | 6  | 7   | (saddr) ← byte                  |   |       |
|          |     | sfr, #byte          | 3  | ı  | 7   | sfr ← byte                      |   |       |
|          |     | A, r                | 1  | 2  | -   | A ← r                           |   |       |
|          |     | r, A <sup>243</sup> | 1  | 2  | -   | $r \leftarrow A$                |   |       |
|          |     | A, saddr            | 2  | 4  | 5   | A ← (saddr)                     |   |       |
|          |     | saddr, A            | 2  | 4  | 5   | (saddr) ← A                     |   |       |
|          |     | A, sfr              | 2  | -  | 5   | A ← sfr                         |   |       |
|          |     | sfr, A              | 2  | =  | 5   | sfr ← A                         |   |       |
|          |     | A, !addr16          | 3  | 8  | 9   | A ← (addr16)                    |   |       |
|          |     | !addr16, A          | 3  | 8  | 9   | (addr16) ← A                    |   |       |
|          |     | PSW, #byte          | 3  | -  | 7   | PSW ← byte                      | × | × ×   |
|          |     | A, PSW              | 2  | =  | 5   | A ← PSW                         |   |       |
|          |     | PSW, A              | 2  | _  | 5   | PSW ← A                         | × | × ×   |
|          |     | A, [DE]             | 1  | 4  | 5   | A ← (DE)                        |   |       |
|          |     | [DE], A             | 1  | 4  | 5   | (DE) ← A                        |   |       |
|          |     | A, [HL]             | 1  | 4  | 5   | A ← (HL)                        |   |       |
|          |     | [HL], A             | 1  | 4  | 5   | (HL) ← A                        |   |       |
|          |     | A, [HL + byte]      | 2  | 8  | 9   | A ← (HL + byte)                 |   |       |
|          |     | [HL + byte], A      | 2  | 8  | 9   | (HL + byte) ← A                 |   |       |
|          |     | A, [HL + B]         | 1  | 6  | 7   | A ← (HL + B)                    |   |       |
|          |     | [HL + B], A         | 1  | 6  | 7   | (HL + B) ← A                    |   |       |
|          |     | A, [HL + C]         | 1  | 6  | 7   | A ← (HL + C)                    |   |       |
|          |     | [HL + C], A         | 1  | 6  | 7   | (HL + C) ← A                    |   |       |
|          | хсн | A, r <b>2</b> ±3    | 1  | 2  | -   | $A \leftrightarrow r$           |   |       |
|          |     | A, saddr            | 2  | 4  | 6   | $A \leftrightarrow (saddr)$     |   |       |
|          |     | A, sfr              | 2  | -  | 6   | $A \leftrightarrow (sfr)$       |   |       |
|          |     | A, !addr16          | 3  | 8  | 10  | $A \leftrightarrow (addr16)$    |   |       |
|          |     | A, [DE]             | 1  | 4  | 6   | $A \leftrightarrow (DE)$        |   |       |
|          |     | A, [HL]             | 1  | 4  | 6   | $A \leftrightarrow (HL)$        |   |       |
|          |     | A, [HL + byte]      | 2  | 8  | 10  | $A \leftrightarrow (HL + byte)$ |   |       |
|          |     | A, [HL + B]         | 2  | 8  | 10  | $A \leftrightarrow (HL + B)$    |   |       |
|          |     | A, [HL + C]         | 2  | 8  | 10  | $A \leftrightarrow (HL + C)$    |   |       |

注: 1. 当访问内部高速 RAM 时或针对无数据访问的指令

- 2. 当访问内部高速 RAM 以外的区域时
- 3. "r=A"除外

**备注:** 1. 一个指令时钟周期是指由处理器时钟控制寄存器(PCC)选择的 CPU 时钟(fcpu)的一个周期。

| 指令组    | 助记符  | 垢 <i>化</i> 粉   | 字节 |    | 时钟  | 操作                                   | 7 | 标志    |
|--------|------|----------------|----|----|-----|--------------------------------------|---|-------|
| 1日マ组   | 助心剂  | 操作数            | 数  | 注1 | 注 2 |                                      | Z | AC CY |
| 16 位数据 | MOVW | rp, #word      | 3  | 6  | 1   | rp ← word                            |   |       |
| 传送     |      | saddrp, #word  | 4  | 8  | 10  | (saddrp) ← word                      |   |       |
|        |      | sfrp, #word    | 4  | 1  | 10  | sfrp ← word                          |   |       |
|        |      | AX, saddrp     | 2  | 6  | 8   | AX ← (saddrp)                        |   |       |
|        |      | saddrp, AX     | 2  | 6  | 8   | (saddrp) ← AX                        |   |       |
|        |      | AX, sfrp       | 2  | 1  | 8   | AX ← sfrp                            |   |       |
|        |      | sfrp, AX       | 2  | 1  | 8   | sfrp ← AX                            |   |       |
|        |      | AX, rp         | 1  | 4  | -   | AX ← rp                              |   |       |
|        |      | rp, AX         | 1  | 4  | ı   | $rp \leftarrow AX$                   |   |       |
|        |      | AX, !addr16    | 3  | 10 | 12  | AX ← (addr16)                        |   |       |
|        |      | !addr16, AX    | 3  | 10 | 12  | (addr16) ← AX                        |   |       |
|        | XCHW | AX, rp ±3      | 1  | 4  | ı   | $AX \leftrightarrow rp$              |   |       |
| 8位操作   | ADD  | A, #byte       | 2  | 4  | Î   | A, CY ← A + byte                     | × | × ×   |
|        |      | saddr, #byte   | 3  | 6  | 8   | (saddr), CY ← (saddr) + byte         | × | × ×   |
|        |      | A, r #4        | 2  | 4  | ı   | $A, CY \leftarrow A + r$             | × | × ×   |
|        |      | r, A           | 2  | 4  | Î   | $r, CY \leftarrow r + A$             | × | × ×   |
|        |      | A, saddr       | 2  | 4  | 5   | A, CY ← A + (saddr)                  | × | × ×   |
|        |      | A, !addr16     | 3  | 8  | 9   | A, CY ← A + (addr16)                 | × | × ×   |
|        |      | A, [HL]        | 1  | 4  | 5   | $A, CY \leftarrow A + (HL)$          | × | × ×   |
|        |      | A, [HL + byte] | 2  | 8  | 9   | A, CY ← A + (HL + byte)              | × | × ×   |
|        |      | A, [HL + B]    | 2  | 8  | 9   | $A, CY \leftarrow A + (HL + B)$      | × | × ×   |
|        |      | A, [HL + C]    | 2  | 8  | 9   | $A, CY \leftarrow A + (HL + C)$      | × | ××    |
|        | ADDC | A, #byte       | 2  | 4  | _   | A, CY ← A + byte + CY                | × | × ×   |
|        |      | saddr, #byte   | 3  | 6  | 8   | (saddr), CY ← (saddr) + byte + CY    | × | ××    |
|        |      | A, r #4        | 2  | 4  | Î   | $A, CY \leftarrow A + r + CY$        | × | × ×   |
|        |      | r, A           | 2  | 4  | Î   | $r, CY \leftarrow r + A + CY$        | × | × ×   |
|        |      | A, saddr       | 2  | 4  | 5   | A, CY ← A + (saddr) + CY             | × | × ×   |
|        |      | A, !addr16     | 3  | 8  | 9   | A, CY ← A + (addr16) + C             | × | × ×   |
|        |      | A, [HL]        | 1  | 4  | 5   | $A, CY \leftarrow A + (HL) + CY$     | × | × ×   |
|        |      | A, [HL + byte] | 2  | 8  | 9   | A, CY ← A + (HL + byte) + CY         | × | × ×   |
|        |      | A, [HL + B]    | 2  | 8  | 9   | $A, CY \leftarrow A + (HL + B) + CY$ | × | × ×   |
|        |      | A, [HL + C]    | 2  | 8  | 9   | $A, CY \leftarrow A + (HL + C) + CY$ | × | × ×   |

- 2. 当访问内部高速 RAM 以外的区域时
- **3.** 仅当 rp = BC, DE 或 HL
- **4.** "r = A"除外

**备注:** 1. 一个指令时钟周期是指由处理器时钟控制寄存器(PCC)选择的 CPU 时钟(fcpu)的一个周期。

| 指令组  | 助记符      | 操作数            | 字节 |     | 时钟  | 操作                                      | 标志      |
|------|----------|----------------|----|-----|-----|-----------------------------------------|---------|
| 相学组  | 助心行      | 採作奴            | 数  | 注 1 | 注 2 | 採作                                      | Z AC CY |
| 8位操作 | SUB      | A, #byte       | 2  | 4   | -   | A, CY ← A – byte                        | x x x   |
|      |          | saddr, #byte   | 3  | 6   | 8   | (saddr), CY ← (saddr) – byte            | x x x   |
|      |          | A, r #3        | 2  | 4   | -   | $A, CY \leftarrow A - r$                | x x x   |
|      |          | r, A           | 2  | 4   | _   | $r, CY \leftarrow r - A$                | x x x   |
|      |          | A, saddr       | 2  | 4   | 5   | A, CY ← A – (saddr)                     | x x x   |
|      |          | A, !addr16     | 3  | 8   | 9   | A, CY ← A – (addr16)                    | x x x   |
|      |          | A, [HL]        | 1  | 4   | 5   | $A, CY \leftarrow A - (HL)$             | x x x   |
|      |          | A, [HL + byte] | 2  | 8   | 9   | A, CY ← A − (HL + byte)                 | x x x   |
|      |          | A, [HL + B]    | 2  | 8   | 9   | A, CY ← A − (HL + B)                    | x x x   |
|      |          | A, [HL + C]    | 2  | 8   | 9   | $A, CY \leftarrow A - (HL + C)$         | x x x   |
|      | SUBC     | A, #byte       | 2  | 4   | _   | A, $CY \leftarrow A - byte - CY$        | × × ×   |
|      |          | saddr, #byte   | 3  | 6   | 8   | (saddr), CY ← (saddr) – byte – CY       | x x x   |
|      |          | A, r 推3        | 2  | 4   | _   | $A, CY \leftarrow A - r - CY$           | × × ×   |
|      |          | r, A           | 2  | 4   | _   | $r, CY \leftarrow r - A - CY$           | × × ×   |
|      |          | A, saddr       | 2  | 4   | 5   | A, CY ← A − (saddr) − CY                | × × ×   |
|      |          | A, !addr16     | 3  | 8   | 9   | A, CY ← A − (addr16) − CY               | × × ×   |
|      |          | A, [HL]        | 1  | 4   | 5   | $A, CY \leftarrow A - (HL) - CY$        | × × ×   |
|      |          | A, [HL + byte] | 2  | 8   | 9   | A, CY ← A − (HL + byte) − CY            | × × ×   |
|      |          | A, [HL + B]    | 2  | 8   | 9   | $A, CY \leftarrow A - (HL + B) - CY$    | × × ×   |
|      |          | A, [HL + C]    | 2  | 8   | 9   | $A, CY \leftarrow A - (HL + C) - CY$    | × × ×   |
|      | AND      | A, #byte       | 2  | 4   | -   | $A \leftarrow A \land byte$             | ×       |
|      |          | saddr, #byte   | 3  | 6   | 8   | $(saddr) \leftarrow (saddr) \land byte$ | ×       |
|      |          | A, r #3        | 2  | 4   | =   | $A \leftarrow A \wedge r$               | ×       |
|      |          | r, A           | 2  | 4   | =   | $r \leftarrow r \wedge A$               | ×       |
|      |          | A, saddr       | 2  | 4   | 5   | $A \leftarrow A \land (saddr)$          | ×       |
|      |          | A, !addr16     | 3  | 8   | 9   | $A \leftarrow A \wedge (addr16)$        | ×       |
|      |          | A, [HL]        | 1  | 4   | 5   | $A \leftarrow A \wedge (HL)$            | ×       |
|      |          | A, [HL + byte] | 2  | 8   | 9   | $A \leftarrow A \wedge (HL + byte)$     | ×       |
|      |          | A, [HL + B]    | 2  | 8   | 9   | $A \leftarrow A \wedge (HL + B)$        | ×       |
|      | <u> </u> | A, [HL + C]    | 2  | 8   | 9   | $A \leftarrow A \wedge (HL + C)$        | ×       |

- 2. 当访问内部高速 RAM 以外的区域时
- **3.** "r = A"除外

备注: 1. 一个指令时钟周期是指由处理器时钟控制寄存器(PCC)选择的 CPU 时钟(fcpu)的一个周期。

| 指令组  | 助记符 | 操作数            | 字节 | ı  | 时钟  | 操作                                | 标志     |  |
|------|-----|----------------|----|----|-----|-----------------------------------|--------|--|
| 相交组  | 奶儿们 | 採作奴            | 数  | 注1 | 注 2 | <b>第</b> 作                        | Z AC C |  |
| 8位操作 | OR  | A, #byte       | 2  | 4  | =   | $A \leftarrow A \lor byte$        | ×      |  |
|      |     | saddr, #byte   | 3  | 6  | 8   | (saddr) ← (saddr) ∨ byte          | ×      |  |
|      |     | A, r #3        | 2  | 4  | _   | $A \leftarrow A \lor r$           | ×      |  |
|      |     | r, A           | 2  | 4  | -   | $r \leftarrow r \lor A$           | ×      |  |
|      |     | A, saddr       | 2  | 4  | 5   | $A \leftarrow A \lor (saddr)$     | ×      |  |
|      |     | A, !addr16     | 3  | 8  | 9   | $A \leftarrow A \lor (addr16)$    | ×      |  |
|      |     | A, [HL]        | 1  | 4  | 5   | $A \leftarrow A \lor (HL)$        | ×      |  |
|      |     | A, [HL + byte] | 2  | 8  | 9   | $A \leftarrow A \lor (HL + byte)$ | ×      |  |
|      |     | A, [HL + B]    | 2  | 8  | 9   | $A \leftarrow A \lor (HL + B)$    | ×      |  |
|      |     | A, [HL + C]    | 2  | 8  | 9   | $A \leftarrow A \lor (HL + C)$    | ×      |  |
|      | XOR | A, #byte       | 2  | 4  | _   | $A \leftarrow A \neq byte$        | ×      |  |
|      |     | saddr, #byte   | 3  | 6  | 8   | (saddr) ← (saddr) + byte          | ×      |  |
|      |     | A, r 2±3       | 2  | 4  | _   | $A \leftarrow A + r$              | ×      |  |
|      |     | r, A           | 2  | 4  | _   | $r \leftarrow r \neq A$           | ×      |  |
|      |     | A, saddr       | 2  | 4  | 5   | A ← A → (saddr)                   | ×      |  |
|      |     | A, !addr16     | 3  | 8  | 9   | A ← A → (addr16)                  | ×      |  |
|      |     | A, [HL]        | 1  | 4  | 5   | $A \leftarrow A \neq (HL)$        | ×      |  |
|      |     | A, [HL + byte] | 2  | 8  | 9   | $A \leftarrow A \neq (HL + byte)$ | ×      |  |
|      |     | A, [HL + B]    | 2  | 8  | 9   | $A \leftarrow A \neq (HL + B)$    | ×      |  |
|      |     | A, [HL + C]    | 2  | 8  | 9   | $A \leftarrow A \neq (HL + C)$    | ×      |  |
|      | СМР | A, #byte       | 2  | 4  | _   | A – byte                          | × × ×  |  |
|      |     | saddr, #byte   | 3  | 6  | 8   | (saddr) – byte                    | × × ×  |  |
|      |     | A, r 2±3       | 2  | 4  | -   | A – r                             | × × ×  |  |
|      |     | r, A           | 2  | 4  | _   | r – A                             | × × ×  |  |
|      |     | A, saddr       | 2  | 4  | 5   | A – (saddr)                       | × × ×  |  |
|      |     | A, !addr16     | 3  | 8  | 9   | A – (addr16)                      | × × ×  |  |
|      |     | A, [HL]        | 1  | 4  | 5   | A – (HL)                          | × × ×  |  |
|      |     | A, [HL + byte] | 2  | 8  | 9   | A – (HL + byte)                   | × × ×  |  |
|      |     | A, [HL + B]    | 2  | 8  | 9   | A – (HL + B)                      | × × ×  |  |
|      |     | A, [HL + C]    | 2  | 8  | 9   | A – (HL + C)                      | × × ×  |  |

2. 当访问内部高速 RAM 以外的区域时

**3.** "r=A"除外

备注: 1. 一个指令时钟周期是指由处理器时钟控制寄存器(PCC)选择的 CPU 时钟(fcpu)的一个周期。

| 指令组    | D4.27.75 | 操作数           | 字节 | f 时钟 |     | +5. <i>Lt-</i>                                                                                                   | 标志      |
|--------|----------|---------------|----|------|-----|------------------------------------------------------------------------------------------------------------------|---------|
| 指令组    | 助记符      |               | 数  | 注 1  | 注 2 | 操作                                                                                                               | Z AC CY |
| 16 位操作 | ADDW     | AX, #word     | 3  | 6    | =   | $AX, CY \leftarrow AX + word$                                                                                    | × × ×   |
|        | SUBW     | AX, #word     | 3  | 6    | -   | $AX, CY \leftarrow AX - word$                                                                                    | × × ×   |
|        | CMPW     | AX, #word     | 3  | 6    | 1   | AX – word                                                                                                        | x x x   |
| 乘法/    | MULU     | X             | 2  | 16   | ı   | $AX \leftarrow A \times X$                                                                                       |         |
| 除法     | DIVUW    | С             | 2  | 25   | ı   | AX (商), C (余数) ← AX ÷ C                                                                                          |         |
| 递增/    | INC      | r             | 1  | 2    | 1   | r ← r + 1                                                                                                        | × ×     |
| 递减     |          | saddr         | 2  | 4    | 6   | (saddr) ← (saddr) + 1                                                                                            | ××      |
|        | DEC      | r             | 1  | 2    | -   | r ← r − 1                                                                                                        | × ×     |
|        |          | saddr         | 2  | 4    | 6   | (saddr) ← (saddr) – 1                                                                                            | × ×     |
|        | INCW     | rp            | 1  | 4    | -   | rp ← rp + 1                                                                                                      |         |
|        | DECW     | rp            | 1  | 4    | -   | rp ← rp − 1                                                                                                      |         |
| R      | ROR      | A, 1          | 1  | 2    | 1   | (CY, A <sub>7</sub> $\leftarrow$ A <sub>0</sub> , A <sub>m-1</sub> $\leftarrow$ A <sub>m</sub> ) $\times$ 1 time | ×       |
|        | ROL      | A, 1          | 1  | 2    | -   | (CY, $A_0 \leftarrow A_7$ , $A_{m+1} \leftarrow A_m$ ) × 1 time                                                  | ×       |
|        | RORC     | A, 1          | 1  | 2    | -   | $(CY \leftarrow A_0, A_7 \leftarrow CY, A_{m-1} \leftarrow A_m) \times 1 \text{ time}$                           | ×       |
|        | ROLC     | A, 1          | 1  | 2    | 1   | $(CY \leftarrow A_7, A_0 \leftarrow CY, A_{m+1} \leftarrow A_m) \times 1 \text{ time}$                           | ×       |
|        | ROR4     | [HL]          | 2  | 10   | 12  | $A_{3-0} \leftarrow (HL)_{3-0}, (HL)_{7-4} \leftarrow A_{3-0},$<br>$(HL)_{3-0} \leftarrow (HL)_{7-4}$            |         |
|        | ROL4     | [HL]          | 2  | 10   | 12  | $A_{3-0} \leftarrow (HL)_{7-4}, (HL)_{3-0} \leftarrow A_{3-0},$<br>$(HL)_{7-4} \leftarrow (HL)_{3-0}$            |         |
| BCD 调整 | ADJBA    |               | 2  | 4    | =   | 加法后的十进制调整                                                                                                        | × × ×   |
|        | ADJBS    |               | 2  | 4    | -   | 减法后的十进制调整                                                                                                        | × × ×   |
| 位操作    | MOV1     | CY, saddr.bit | 3  | 6    | 7   | CY ← (saddr.bit)                                                                                                 | ×       |
|        |          | CY, sfr.bit   | 3  | _    | 7   | CY ← sfr.bit                                                                                                     | ×       |
|        |          | CY, A.bit     | 2  | 4    | _   | CY ← A.bit                                                                                                       | ×       |
|        |          | CY, PSW.bit   | 3  | _    | 7   | CY ← PSW.bit                                                                                                     | ×       |
|        |          | CY, [HL].bit  | 2  | 6    | 7   | CY ← (HL).bit                                                                                                    | ×       |
|        |          | saddr.bit, CY | 3  | 6    | 8   | (saddr.bit) ← CY                                                                                                 |         |
|        |          | sfr.bit, CY   | 3  | _    | 8   | sfr.bit ← CY                                                                                                     |         |
|        |          | A.bit, CY     | 2  | 4    |     | A.bit ← CY                                                                                                       |         |
|        |          | PSW.bit, CY   | 3  |      | 8   | PSW.bit ← CY                                                                                                     | × ×     |
|        |          | [HL].bit, CY  | 2  | 6    | 8   | (HL).bit ← CY                                                                                                    |         |

2. 当访问内部高速 RAM 以外的区域时

**备注:** 1. 一个指令时钟周期是指由处理器时钟控制寄存器(PCC)选择的 CPU 时钟(fcpu)的一个周期。

| 指令组  | 助记符  | 操作数           | 字节 | 时钟  |     | 操作                                | 标志      |
|------|------|---------------|----|-----|-----|-----------------------------------|---------|
| 1日マ组 | 助此刊  |               | 数  | 注 1 | 注 2 | 1 <del>米</del> 1F                 | Z AC CY |
| 位操作  | AND1 | CY, saddr.bit | 3  | 6   | 7   | CY ← CY ∧ (saddr.bit)             | ×       |
|      |      | CY, sfr.bit   | 3  | _   | 7   | CY ← CY ∧ sfr.bit                 | ×       |
|      |      | CY, A.bit     | 2  | 4   | =   | $CY \leftarrow CY \wedge A.bit$   | ×       |
|      |      | CY, PSW.bit   | 3  | _   | 7   | $CY \leftarrow CY \land PSW.bit$  | ×       |
|      |      | CY, [HL].bit  | 2  | 6   | 7   | $CY \leftarrow CY \land (HL).bit$ | ×       |
|      | OR1  | CY, saddr.bit | 3  | 6   | 7   | CY ← CY ∨ (saddr.bit)             | ×       |
|      |      | CY, sfr.bit   | 3  | _   | 7   | $CY \leftarrow CY \lor sfr.bit$   | ×       |
|      |      | CY, A.bit     | 2  | 4   | -   | CY ← CY ∨ A.bit                   | ×       |
|      |      | CY, PSW.bit   | 3  | _   | 7   | $CY \leftarrow CY \lor PSW.bit$   | ×       |
|      |      | CY, [HL].bit  | 2  | 6   | 7   | CY ← CY ∨ (HL).bit                | ×       |
|      | XOR1 | CY, saddr.bit | 3  | 6   | 7   | CY ← CY <del>∨</del> (saddr.bit)  | ×       |
|      |      | CY, sfr.bit   | 3  | _   | 7   | CY ← CY <del>∨</del> sfr.bit      | ×       |
|      |      | CY, A.bit     | 2  | 4   | -   | CY ← CY ¥ A.bit                   | ×       |
|      |      | CY, PSW. bit  | 3  | _   | 7   | CY ← CY <del>∨</del> PSW.bit      | ×       |
|      |      | CY, [HL].bit  | 2  | 6   | 7   | CY ← CY → (HL).bit                | ×       |
|      | SET1 | saddr.bit     | 2  | 4   | 6   | (saddr.bit) ← 1                   |         |
|      |      | sfr.bit       | 3  | _   | 8   | sfr.bit ← 1                       |         |
|      |      | A.bit         | 2  | 4   | -   | A.bit ← 1                         |         |
|      |      | PSW.bit       | 2  | _   | 6   | PSW.bit ← 1                       | × × ×   |
|      |      | [HL].bit      | 2  | 6   | 8   | (HL).bit ← 1                      |         |
|      | CLR1 | saddr.bit     | 2  | 4   | 6   | (saddr.bit) ← 0                   |         |
|      |      | sfr.bit       | 3  | _   | 8   | sfr.bit ← 0                       |         |
|      |      | A.bit         | 2  | 4   | _   | A.bit ← 0                         |         |
|      |      | PSW.bit       | 2  | _   | 6   | PSW.bit ← 0                       | × × ×   |
|      |      | [HL].bit      | 2  | 6   | 8   | (HL).bit ← 0                      |         |
|      | SET1 | CY            | 1  | 2   | -   | CY ← 1                            | 1       |
|      | CLR1 | CY            | 1  | 2   | -   | CY ← 0                            | 0       |
|      | NOT1 | CY            | 1  | 2   | -   | $CY \leftarrow \overline{CY}$     | ×       |

2. 当访问内部高速 RAM 以外的区域时

备注: 1. 一个指令时钟周期是指由处理器时钟控制寄存器(PCC)选择的 CPU 时钟(fcpu)的一个周期。

| +K A /H | ロ4. )コ <i>か</i> ケ | 操作数         | 字节 |     | 时钟  | +55. Ib-                                                                                                                                                                                                   | ŧ | 示志   | П  |
|---------|-------------------|-------------|----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|----|
| 指令组     | 助记符               | <b>米</b> 下奴 | 数  | 注 1 | 注 2 | 操作                                                                                                                                                                                                         | Z | AC ( | CY |
| 调用/返回   | CALL              | !addr16     | 3  | 7   | =   | $(SP-1) \leftarrow (PC+3)H, (SP-2) \leftarrow (PC+3)L,$<br>PC \leftarrow addr16, SP \leftarrow SP-2                                                                                                        |   |      |    |
|         | CALLF             | !addr11     | 2  | 5   | =   | $(SP - 1) \leftarrow (PC + 2)H, (SP - 2) \leftarrow (PC + 2)L,$<br>$PC_{15-11} \leftarrow 00001, PC_{10-0} \leftarrow addr11,$<br>$SP \leftarrow SP - 2$                                                   |   |      |    |
|         | CALLT             | [addr5]     | 1  | 6   | _   | $\begin{split} &(SP-1) \leftarrow (PC+1)_{H},  (SP-2) \leftarrow (PC+1)_{L}, \\ &PC_{H} \leftarrow (00000000,  addr5+1), \\ &PC_{L} \leftarrow (00000000,  addr5), \\ &SP \leftarrow SP-2 \end{split}$     |   |      |    |
|         | BRK               |             | 1  | 6   | _   | $\begin{split} (SP-1) \leftarrow PSW,  (SP-2) \leftarrow (PC+1)_H, \\ (SP-3) \leftarrow (PC+1)_L,  PC_H \leftarrow (003FH), \\ PC_L \leftarrow (003EH),  SP \leftarrow SP-3,  IE \leftarrow 0 \end{split}$ |   |      |    |
|         | RET               |             | 1  | 6   | -   | $PCH \leftarrow (SP + 1), PCL \leftarrow (SP),$<br>$SP \leftarrow SP + 2$                                                                                                                                  |   |      |    |
|         | RETI              |             | 1  | 6   | -   | PCH $\leftarrow$ (SP + 1), PCL $\leftarrow$ (SP),<br>PSW $\leftarrow$ (SP + 2), SP $\leftarrow$ SP + 3                                                                                                     | R | R    | R  |
|         | RETB              |             | 1  | 6   | _   | PCH $\leftarrow$ (SP + 1), PCL $\leftarrow$ (SP),<br>PSW $\leftarrow$ (SP + 2), SP $\leftarrow$ SP + 3                                                                                                     | R | R    | R  |
| 堆栈操作    | PUSH              | PSW         | 1  | 2   | -   | $(SP - 1) \leftarrow PSW, SP \leftarrow SP - 1$                                                                                                                                                            |   |      |    |
|         |                   | rp          | 1  | 4   | -   | $(SP - 1) \leftarrow rpH, (SP - 2) \leftarrow rpL,$<br>$SP \leftarrow SP - 2$                                                                                                                              |   |      |    |
|         | POP               | PSW         | 1  | 2   | _   | $PSW \leftarrow (SP),SP \leftarrow SP + 1$                                                                                                                                                                 | R | R    | R  |
|         |                   | rp          | 1  | 4   | _   | $rpH \leftarrow (SP + 1), rpL \leftarrow (SP),$<br>$SP \leftarrow SP + 2$                                                                                                                                  |   |      |    |
|         | MOVW              | SP, #word   | 4  | _   | 10  | SP ← word                                                                                                                                                                                                  |   |      |    |
|         |                   | SP, AX      | 2  | _   | 8   | SP ← AX                                                                                                                                                                                                    |   |      |    |
|         |                   | AX, SP      | 2  | -   | 8   | AX ← SP                                                                                                                                                                                                    |   |      |    |
| 无条件转移   | BR                | !addr16     | 3  | 6   | _   | PC ← addr16                                                                                                                                                                                                |   |      |    |
|         |                   | \$addr16    | 2  | 6   | _   | PC ← PC + 2 + jdisp8                                                                                                                                                                                       |   |      |    |
|         |                   | AX          | 2  | 8   | _   | PCH ← A, PCL ← X                                                                                                                                                                                           |   |      |    |
| 条件转移    | ВС                | \$addr16    | 2  | 6   | _   | 如果 CY = 1,则 PC ← PC + 2 + jdisp8                                                                                                                                                                           |   |      |    |
|         | BNC               | \$addr16    | 2  | 6   | -   | 如果 CY =0,则 PC ← PC + 2 + jdisp8                                                                                                                                                                            |   |      |    |
|         | BZ                | \$addr16    | 2  | 6   | -   | 如果 Z = 1,则 PC ← PC + 2 + jdisp8                                                                                                                                                                            |   |      |    |
|         | BNZ               | \$addr16    | 2  | 6   | _   | 如果 Z = 0,则 PC ← PC + 2 + jdisp8                                                                                                                                                                            |   |      |    |

2. 当访问内部高速 RAM 以外的区域时

备注: 1. 一个指令时钟周期是指由处理器时钟控制寄存器(PCC)选择的 CPU 时钟(fcru)的一个周期。

| #5 A MI | <b>山 コか</b> | 15. Ur. Wr.         | 字节 | 时钟  |     | +55. Ib-                                                          | 杉 | 示志    |
|---------|-------------|---------------------|----|-----|-----|-------------------------------------------------------------------|---|-------|
| 指令组     | 助记符         | 操作数                 | 数  | 注 1 | 注 2 | 操作                                                                | Z | AC CY |
| 条件转移    | вт          | saddr.bit, \$addr16 | 3  | 8   | 9   | 如果(saddr.bit) = 1,则 PC ← PC + 3 + jdisp8                          |   |       |
|         |             | sfr.bit, \$addr16   | 4  | =   | 11  | 如果 sfr.bit = 1,则 PC ← PC + 4 + jdisp8                             |   |       |
|         |             | A.bit, \$addr16     | 3  | 8   | -   | 如果 A.bit = 1,则 PC ← PC + 3 + jdisp8                               |   |       |
|         |             | PSW.bit, \$addr16   | 3  | _   | 9   | 如果 PSW.bit = 1,则 PC ← PC + 3 + jdisp8                             |   |       |
|         |             | [HL].bit, \$addr16  | 3  | 10  | 11  | 如果(HL).bit = 1,则 PC ← PC + 3 + jdisp8                             |   |       |
|         | BF          | saddr.bit, \$addr16 | 4  | 10  | 11  | 如果(saddr.bit) = 0,则 PC ← PC + 4 + jdisp8                          |   |       |
|         |             | sfr.bit, \$addr16   | 4  | _   | 11  | 如果 sfr.bit = 0,则 PC ← PC + 4 + jdisp8                             |   |       |
|         |             | A.bit, \$addr16     | 3  | 8   | _   | 如果 A.bit = 0,则 PC ← PC + 3 + jdisp8                               |   |       |
|         |             | PSW.bit, \$addr16   | 4  | -   | 11  | 如果 PSW. bit = 0,则 PC ← PC + 4 + jdisp8                            |   |       |
|         |             | [HL].bit, \$addr16  | 3  | 10  | 11  | 如果 (HL).bit = 0,则 PC ← PC + 3 + jdisp8                            |   |       |
|         | BTCLR       | saddr.bit, \$addr16 | 4  | 10  | 12  | 如果(saddr.bit) = 1,则 PC ← PC + 4 + jdisp8<br>然后复位(saddr.bit)       |   |       |
|         |             | sfr.bit, \$addr16   | 4  | -   | 12  | 如果 sfr.bit = 1,则 PC $\leftarrow$ PC + 4 + jdisp8 然后复位 sfr.bit     |   |       |
|         |             | A.bit, \$addr16     | 3  | 8   | =   | 如果 A.bit = 1,则 PC ← PC + 3 + jdisp8<br>然后复位 A.bit                 |   |       |
|         |             | PSW.bit, \$addr16   | 4  | -   | 12  | 如果 PSW.bit = 1,则 PC $\leftarrow$ PC + 4 + jdisp8 然后复位 PSW.bit     | × | × ×   |
|         |             | [HL].bit, \$addr16  | 3  | 10  | 12  | 如果(HL).bit = 1,则 PC ← PC + 3 + jdisp8<br>然后复位 (HL).bit            |   |       |
|         | DBNZ        | B, \$addr16         | 2  | 6   | =   | B ← B − 1, 然后<br>如果 B ≠ 0,则 PC ← PC + 2 + jdisp8                  |   |       |
|         |             | C, \$addr16         | 2  | 6   | =   | C ← C –1, 然后<br>如果 C ≠ 0,则 PC ← PC + 2 + jdisp8                   |   |       |
|         |             | saddr, \$addr16     | 3  | 8   | 10  | (saddr) ← (saddr) – 1, 然后<br>如果(saddr) ≠ 0,则 PC ← PC + 3 + jdisp8 |   |       |
| CPU 控制  | SEL         | RBn                 | 2  | 4   | -   | RBS1, 0 ← n                                                       |   |       |
|         | NOP         |                     | 1  | 2   | =   | 无操作                                                               |   |       |
|         | EI          |                     | 2  | _   | 6   | IE ← 1 (允许中断)                                                     |   |       |
|         | DI          |                     | 2  | _   | 6   | IE ← 0 (禁止中断)                                                     |   |       |
|         | HALT        |                     | 2  | 6   | _   | 设置 HALT 模式                                                        |   |       |
|         | STOP        |                     | 2  | 6   | -   | 设置 STOP 模式                                                        |   |       |

2. 当访问内部高速 RAM 以外的区域时

备注: 1. 一个指令时钟周期是指由处理器时钟控制寄存器(PCC)选择的 CPU 时钟(fcpu)的一个周期。

# 29.3 按寻址类型列出指令

## (1) 8位指令

MOV, XCH, ADD, ADDC, SUB, SUBC, AND, OR, XOR, CMP, MULU, DIVUW, INC, DEC, ROR, ROL, RORC, ROLC, ROR4, ROL4, PUSH, POP, DBNZ

| 第2操作数                               | #byte                                                        | А                                                            | r <sup>#</sup>                                                      | sfr        | saddr                                                               | !addr16                                                             | PSW | [DE]       | [HL]                                                                | [HL+byte]<br>[HL+B]<br>[HL+C]                                       |      | 1                          | 无            |
|-------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------|------------|---------------------------------------------------------------------|---------------------------------------------------------------------|-----|------------|---------------------------------------------------------------------|---------------------------------------------------------------------|------|----------------------------|--------------|
| А                                   | ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP        |                                                              | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV<br>XCH | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV | MOV<br>XCH | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |      | ROR<br>ROL<br>RORC<br>ROLC |              |
| r                                   | MOV                                                          | MOV<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | INC<br>DEC   |
| B, C                                |                                                              |                                                              |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     | DBNZ |                            |              |
| sfr                                 | MOV                                                          | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            |              |
| saddr                               | MOV<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     | DBNZ |                            | INC<br>DEC   |
| !addr16                             |                                                              | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            |              |
| PSW                                 | MOV                                                          | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | PUSH<br>POP  |
| [DE]                                |                                                              | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            |              |
| [HL]                                |                                                              | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | ROR4<br>ROL4 |
| [HL + byte]<br>[HL + B]<br>[HL + C] |                                                              | MOV                                                          |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            |              |
| Х                                   |                                                              |                                                              |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | MULU         |
| С                                   |                                                              |                                                              |                                                                     |            |                                                                     |                                                                     |     |            |                                                                     |                                                                     |      |                            | DIVUW        |

注: "r = A" 除外

# (2) 16 位指令

MOVW, XCHW, ADDW, SUBW, CMPW, PUSH, POP, INCW, DECW

| 第 2 操作数 | #word                | AX     | rp <sup>ž</sup> | sfrp | saddrp | !addr16 | SP   | 无                           |
|---------|----------------------|--------|-----------------|------|--------|---------|------|-----------------------------|
| 第 1 操作数 |                      |        |                 |      |        |         |      |                             |
| AX      | ADDW<br>SUBW<br>CMPW |        | MOVW<br>XCHW    | MOVW | MOVW   | MOVW    | MOVW |                             |
| гр      | MOVW                 | MOVW * |                 |      |        |         |      | INCW<br>DECW<br>PUSH<br>POP |
| sfrp    | MOVW                 | MOVW   |                 |      |        |         |      |                             |
| saddrp  | MOVW                 | MOVW   |                 |      |        |         |      |                             |
| !addr16 |                      | MOVW   |                 |      |        |         |      |                             |
| SP      | MOVW                 | MOVW   |                 |      |        |         |      |                             |

**注:** 仅当 rp = BC, DE, HL 时使用

## (3) 位操作指令

MOV1, AND1, OR1, XOR1, SET1, CLR1, NOT1, BT, BF, BTCLR

| 第 2 操作数          | A.bit                       | sfr.bit                     | saddr.bit                   | PSW.bit                     | [HL].bit                    | CY   | \$addr16          | 无                    |
|------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|------|-------------------|----------------------|
| 第 1 操作数<br>A.bit |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| sfr.bit          |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| saddr.bit        |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| PSW.bit          |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| [HL].bit         |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| СҮ               | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 |      |                   | SET1<br>CLR1<br>NOT1 |

# (4) 调用指令/转移指令

 $\mathsf{CALL},\,\mathsf{CALLF},\,\mathsf{CALLT},\,\mathsf{BR},\,\mathsf{BC},\,\mathsf{BNC},\,\mathsf{BZ},\,\mathsf{BNZ},\,\mathsf{BT},\,\mathsf{BF},\,\mathsf{BTCLR},\,\mathsf{DBNZ}$ 

| 第2操作数 | AX | !addr16    | !addr11 | [addr5] | \$addr16                     |
|-------|----|------------|---------|---------|------------------------------|
| 基本指令  | BR | CALL<br>BR | CALLF   | CALLT   | BR<br>BC<br>BNC<br>BZ<br>BNZ |
| 复合指令  |    |            |         |         | BT<br>BF<br>BTCLR<br>DBNZ    |

# (5) 其它指令

ADJBA, ADJBS, BRK, RET, RETI, RETB, SEL, NOP, EI, DI, HALT, STOP

## 第三十章 电子产品规范(目标系统)

- 注意事项: 1. 这些规范表示(T)(S)和(R)产品的目标值,在设备评估后可能会改变。
  - 2. μPD78F0547D 具有片上调试功能。不要将该产品用于大规模生产,因为在给定闪存重写次数的条件下,使用片上调试功能后,产品的可靠性得不到保证。NEC Electronics 不接受有关该产品的任何投诉。

#### 最大额定值 (TA = 25°C) (1/2)

| 参数      | 符号                  |                    | 条件                                                                                                | 额定值                                                                                   | 单位 |
|---------|---------------------|--------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|----|
| 供电电压    | V <sub>DD</sub>     |                    |                                                                                                   | –0.5 $\sim$ +6.5                                                                      | V  |
|         | EV <sub>DD</sub>    |                    |                                                                                                   | –0.5 $\sim$ +6.5                                                                      | V  |
|         | Vss                 |                    |                                                                                                   | –0.5 $\sim$ +0.3                                                                      | V  |
|         | EVss                |                    |                                                                                                   | –0.5 $\sim$ +0.3                                                                      | V  |
|         | AVREF               |                    |                                                                                                   | $-0.5 \sim 	extstyle V_{	extstyle DD}$ + $0.3^{lapha}$                                | V  |
|         | AVss                |                    |                                                                                                   | –0.5 $\sim$ +0.3                                                                      | V  |
| 输入电压    | 入电压 V <sub>I1</sub> |                    | 10 ~ P17, P20 ~ P27,<br>40 ~ P47, P50 ~ P57,<br>70 ~ P77, P120 ~ P124,<br>X1, X2, XT1, XT2, RESET | –0.3 $\sim$ V <sub>DD</sub> + 0.3 $^{tt}$                                             | V  |
|         | V <sub>12</sub>     | P60 $\sim$ P63 (N- | -ch 漏极开路)                                                                                         | –0.3 $\sim$ +6.5                                                                      | V  |
| 输出电压    | Vo                  |                    |                                                                                                   | $-0.3\sim$ V <sub>DD</sub> + $0.3$ $^{*\pm}$                                          | V  |
| 模拟输入电压  | Van                 | ANIO $\sim$ ANI7   |                                                                                                   | $-0.3\sim AV_{REF}$ + $0.3^{\mathtt{lt}}$ and $-0.3\sim V_{DD}$ + $0.3^{\mathtt{lt}}$ | ٧  |
| 输出电流, 高 | Іон                 | 每个引脚               |                                                                                                   | -10                                                                                   | mA |
|         |                     | 所有引脚总和<br>-80 mA   | P00 ~ P04, P40 ~<br>P47, P120, P130, P140<br>~ P145                                               | -25                                                                                   | mA |
|         |                     |                    | P05, P06, P10 ~ P17,<br>P30 ~ P33, P50 ~<br>P57, P64 ~ P67, P70<br>~ P77                          | -55                                                                                   | mA |

注: 必须小于等于 6.5 V。

注意事项:任何一项参数哪怕是在瞬间超过最大额定值,都会使产品质量受到影响。也就是说,最大额定值是产品濒临物理损坏的临界点,因而,必须保证产品在不超过最大额定值的条件下使用。

## 最大额定值 (TA = 25°C) (2/2)

| 参数      | 符号               |                  | 条件                                                                       | 额定值             | 单位 |
|---------|------------------|------------------|--------------------------------------------------------------------------|-----------------|----|
| 输出电流, 低 | loL              | 每个引脚             |                                                                          | 30              | mA |
|         |                  | 所有引脚总和<br>200 mA | P00 ~ P04, P40 ~<br>P47, P120, P130, P140<br>~ P145                      | 60              | mA |
|         |                  |                  | P05, P06, P10 ~ P17,<br>P30 ~ P33, P50 ~<br>P57, P60 ~ P67, P70<br>~ P77 | 140             | mA |
| 工作环境温度  | Та               | 正常操作模式           |                                                                          | -40 ∼ +85       | °C |
|         |                  | 闪存编程模式           |                                                                          |                 |    |
| 储藏温度    | T <sub>stg</sub> |                  |                                                                          | –40 $\sim$ +150 | °C |

注意事项:任何一项参数哪怕是在瞬间超过最大额定值,都会使产品质量受到影响。也就是说,最大额定值是产品濒临物理损坏的临界点,因而,必须保证产品在不超过最大额定值的条件下使用。

#### X1 振荡器特性

 $(T_A = -40 \sim +85^{\circ}C, 1.8 \text{ V} \leq V_{DD} = EV_{DD} \leq 5.5 \text{ V}, V_{SS} = EV_{SS} = AV_{SS} = 0 \text{ V})$ 

| 振荡器   | 建议使用的电路                                | 参数                             | 条件                                                | MIN. | TYP. | MAX. | 单位  |
|-------|----------------------------------------|--------------------------------|---------------------------------------------------|------|------|------|-----|
| 陶瓷振荡器 | Vss X1 X2                              | X1 时钟振荡频率<br>(fx) <sup>±</sup> | $4.0~V \leq V_{DD} \leq 5.5~V$                    | 1.0  |      | 20.0 | MHz |
|       | C1= C2=                                |                                | 2.7 V ≤ V <sub>DD</sub> < 4.0 V                   | 1.0  |      | 10.0 |     |
|       | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                                | $1.8~V \leq V_{DD} < 2.7~V$                       | 1.0  |      | 5.0  |     |
| 晶体振荡器 | Vss X1 X2                              | X1 时钟振荡频率<br>(fx) <sup>推</sup> | $4.0~V \leq V_{DD} \leq 5.5~V$                    | 1.0  |      | 20.0 | MHz |
|       | C1= C2=                                |                                | 2.7 V ≤ V <sub>DD</sub> < 4.0 V                   | 1.0  |      | 10.0 |     |
|       | <i>m</i>                               |                                | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V}$ | 1.0  |      | 5.0  |     |

注: 仅表示振荡器的特性。如需了解指令执行时间,可参见 AC 特性。

注意事项: 1. 在使用 X1 时钟时,上图中被虚线包围的部分的配线应按照如下配线方法配线,以防止连接线电容产生不利影响。

- 连接线越短越好。
- 连接线不应与其他信号线交叉。
- 流经的电流变化较大的信号线不要在振荡器周围布线。
- 要保持振荡器电容器的接地点电压与 Vss 相同。
- 不要将电容的地信号接入大电流地。
- 不要从振荡器获取信号。
- 2. 由于复位后 CPU 使用内部高速振荡时钟进行操作,因此用户要使用振荡稳定时间计数器的状态寄存器 (OSTC) 检测 X1 时钟振荡稳定时间。在充分评估了所使用的振荡器的振荡稳定时间后再确定 OSTC 和振荡稳定时间选择寄存器 (OSTS) 的振荡稳定时间。

**备注:** 对于振荡器选择和振荡器常数,用户需要自己评估振荡器或要求制造商评估。

#### 内部振荡器特性

 $(T_A = -40 \sim +85^{\circ}C, 1.8 \text{ V} \leq V_{DD} = EV_{DD} \leq 5.5 \text{ V}, V_{SS} = EV_{SS} = AV_{SS} = 0 \text{ V})$ 

| 振荡器           | 参数                             | 条件                                                       | MIN.              | TYP.     | MAX.      | 单位  |
|---------------|--------------------------------|----------------------------------------------------------|-------------------|----------|-----------|-----|
| 8 MHz 内部振荡器   | 内部高速振荡时钟频率 (frH) <sup>推1</sup> | $2.7~\text{V} \leq \text{V}_\text{DD} \leq 5.5~\text{V}$ | 7.6 ** 2          | 8.0 ** 2 | 8.4 ** 2  | MHz |
|               |                                | 1.8 V ≤ V <sub>DD</sub> < 2.7 V                          | 7.6 <sup>建2</sup> | 8.0 ** 2 | 10.4 ** 2 | MHz |
| 240 kHz 内部振荡器 | 内部低速振荡时钟频率 (fRL)               | $2.7~\text{V} \leq \text{V}_\text{DD} \leq 5.5~\text{V}$ | 216               | 240      | 264       | kHz |
|               |                                | 1.8 V ≤ V <sub>DD</sub> < 2.7 V                          | 120               | 240      | 264       | kHz |

- 注: 1. 仅表示振荡器的特性。如需了解指令执行时间,可参见 AC 特性。
  - 2. 当 RSTS (内部振荡模式寄存器(RCM) 的第7位) = 1 时表示频率。当 RSTS=0 时为 5.6 MHz (TYP.)。

#### XT1 振荡器特性

 $(T_A = -40 \sim +85^{\circ}C, 1.8 \text{ V} \leq V_{DD} = EV_{DD} \leq 5.5 \text{ V}, V_{SS} = EV_{SS} = AV_{SS} = 0 \text{ V})$ 

| 振荡器   | 建议使用的电路     | 参数                            | 条件 | MIN. | TYP.   | MAX. | 单位  |
|-------|-------------|-------------------------------|----|------|--------|------|-----|
| 晶体振荡器 | Vss XT2 XT1 | XT1 时钟振荡频率 (fxт) <sup>#</sup> |    | 32   | 32.768 | 35   | kHz |

- 注: 仅表示振荡器的特性。如需了解指令执行时间,可参见 AC 特性。
- 注意事项: 1. 在使用 X1 时钟时,上图中被虚线包围的部分的配线应按照如下配线方法配线,以防止连接线电容产生不利影响。
  - 连接线越短越好。
  - 连接线不应与其他信号线交叉。
  - 流经的电流变化较大的信号线不要在振荡器周围布线。
  - 要保持振荡器电容器的接地点电压与 Vss 相同。
  - 不要将电容的地信号接入大电流地。
  - 不要从振荡器获取信号。
  - 2. XT1 振荡器是一个低振幅电路,用于降低功耗,但由于比 X1 振荡器更容易受到噪音干扰,因此在使用 XT1 时钟时应特别注意连线方式。

**备注:** 对于振荡器选择和振荡器常数,用户需要自己评估振荡器或要求制造商评估。

#### DC 特性 (1/4)

#### $(T_A = -40 \sim +85^{\circ}C, 1.8 \text{ V} \leq V_{DD} = EV_{DD} \leq 5.5 \text{ V}, AV_{REF} \leq V_{DD}, V_{SS} = EV_{SS} = AV_{SS} = 0 \text{ V})$

| 参数                   | 符号               | 条件                                                          |                                                            | MIN. | TYP. | MAX.  | 单位 |
|----------------------|------------------|-------------------------------------------------------------|------------------------------------------------------------|------|------|-------|----|
| 输出电流,高 <sup>±1</sup> | <b>І</b> он1     | P00 $\sim$ P06, P10 $\sim$ P17, P30 $\sim$                  | $4.0~V \leq V_{DD} \leq 5.5~V$                             |      |      | -3.0  | mA |
|                      |                  | P33, P40 ~ P47, P50 ~ P57,                                  | 2.7 V ≤ V <sub>DD</sub> < 4.0 V                            |      |      | -2.5  | mA |
|                      |                  | P64 ~ P67, P70 ~ P77, P120,<br>P130, P140 ~ P145 的每个引脚      | 1.8 V ≤ V <sub>DD</sub> < 2.7 V                            |      |      | -1.0  | mA |
|                      |                  | P00 ~ P04, P40 ~ P47, P120,                                 | $4.0~V \leq V_{DD} \leq 5.5~V$                             |      |      | -20.0 | mA |
|                      |                  | P130, P140 ~ P145 的所有引脚 <sup>性</sup>                        | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$          |      |      | -10.0 | mA |
|                      |                  |                                                             | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V}$          |      |      | -5.0  | mA |
|                      |                  | P05, P06, P10 $\sim$ P17, P30 $\sim$                        | $4.0~V \leq V_{DD} \leq 5.5~V$                             |      |      | -30.0 | mA |
|                      |                  | P33, P50 ~ P57, P64 ~ P67,                                  | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$          |      |      | -19.0 | mA |
|                      |                  | P70 ~ P77 的所有引脚 <sup>胜3</sup>                               | 1.8 V ≤ V <sub>DD</sub> < 2.7 V                            |      |      | -10.0 | mA |
|                      |                  | 所有引脚 <sup>性3</sup>                                          | $4.0~\text{V} \leq \text{V}_{\text{DD}} \leq 5.5~\text{V}$ |      |      | -50.0 | mA |
|                      |                  |                                                             | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$          |      |      | -29.0 | mA |
|                      |                  |                                                             | 1.8 V ≤ V <sub>DD</sub> < 2.7 V                            |      |      | -15.0 | mA |
|                      | <b>I</b> OH2     | P20 ~ P27 的每个引脚                                             | AVREF = VDD                                                |      |      | -0.1  | mA |
|                      |                  | P121 ~ P124 的每个引脚                                           |                                                            |      |      | -0.1  | mA |
| 输出电流,低 <sup>±2</sup> | lo <sub>L1</sub> | P00 $\sim$ P06, P10 $\sim$ P17, P30 $\sim$                  | $4.0~\text{V} \leq \text{V}_{\text{DD}} \leq 5.5~\text{V}$ |      |      | 8.5   | mA |
|                      |                  | P33, P40 ~ P47, P50 ~ P57,                                  | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$          |      |      | 5.0   | mA |
|                      |                  | P64 ~ P67, P70 ~ P77, P120,<br>P130, P140 ~ P145 的每个引脚      | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V}$          |      |      | 2.0   | mA |
|                      |                  | P60 ~ P63 的每个引脚                                             | $4.0~V \leq V_{DD} \leq 5.5~V$                             |      |      | 15.0  | mA |
|                      |                  |                                                             | $2.7 \text{ V} \leq \text{V}_{DD} < 4.0 \text{ V}$         |      |      | 5.0   | mA |
|                      |                  |                                                             | $1.8 \text{ V} \leq \text{V}_{DD} < 2.7 \text{ V}$         |      |      | 2.0   | mA |
|                      |                  | P00 ~ P04, P40 ~ P47, P120,                                 | $4.0~V \leq V_{DD} \leq 5.5~V$                             |      |      | 20.0  | mA |
|                      |                  | P130, P140 ~ P145 的所有引脚 <sup>性</sup>                        | $2.7 \text{ V} \leq \text{V}_{DD} < 4.0 \text{ V}$         |      |      | 15.0  | mA |
|                      |                  |                                                             | $1.8 \text{ V} \leq \text{V}_{DD} < 2.7 \text{ V}$         |      |      | 9.0   | mA |
|                      |                  | P05, P06, P10 $\sim$ P17, P30 $\sim$                        | $4.0~V \leq V_{DD} \leq 5.5~V$                             |      |      | 45.0  | mA |
|                      |                  | P33, P50 ~ P57, P60 ~ P67,<br>P70 ~ P77 的所有引脚 <sup>推3</sup> | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$          |      |      | 35.0  | mA |
|                      |                  | P70 ~ P77 的所有切脚                                             | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V}$          |      |      | 20.0  | mA |
|                      |                  | 所有引脚总和 <sup>推3</sup>                                        | $4.0~V \leq V_{DD} \leq 5.5~V$                             |      |      | 65.0  | mA |
|                      |                  |                                                             | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$          |      |      | 50.0  | mA |
|                      |                  |                                                             | 1.8 V ≤ V <sub>DD</sub> < 2.7 V                            |      |      | 29.0  | mA |
|                      | lo <sub>L2</sub> | P20 ~ P27 的每个引脚                                             | AVREF = VDD                                                |      |      | 0.4   | mA |
|                      |                  | P121 ~ P124 的每个引脚                                           |                                                            |      |      | 0.4   | mA |

- 注: 1. 即使电流从 Vod 流向输出引脚,设备操作时的电流值也可以得到保证。
  - 2. 即使电流从输出引脚流向 GND,设备操作时的电流值也可以得到保证。
  - **3.** 占空比=70%时 (输出电流的时间为  $0.7 \times t$ ,不输出电流的时间为  $0.3 \times t$ , 其中 t 为指定时间)的规定。可通过以下表达式计算占空比不等于 70%时的引脚总的输出电流。
    - 当 IoH 的占空比为 n%: 引脚总的输出电流 = (IoH × 0.7)/(n × 0.01)

<举例> 当占空比为 50%, Iон = 20.0 mA

引脚总的输出电流 =  $(20.0 \times 0.7)/(50 \times 0.01)$  = 28.0 mA

但是,允许流入每个引脚的电流不会随占空比而变化。高于最大额定值的电流不能流入引脚。

# DC 特性 (2/4)

# (Ta = -40 $\sim$ +85°C, 1.8 V $\leq$ Vdd = EVdd $\leq$ 5.5 V, AVREF $\leq$ Vdd, Vss = EVss = AVss = 0 V)

| 参数      | 符号               | 条件                                                                   | ‡                                                                                                     | MIN.                  | TYP. | MAX.                 | 单位 |
|---------|------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------------------|------|----------------------|----|
| 输入电压, 高 | V <sub>IH1</sub> | P02, P12, P13, P15, P40 ~<br>~ P67, P121 ~ P124, P14                 |                                                                                                       | 0.7V <sub>DD</sub>    |      | V <sub>DD</sub>      | V  |
|         | V <sub>IH2</sub> | P00, P01, P03 ~ P06, P10<br>P30 ~ P33, P60 ~ P62, P<br>~ P143, RESET |                                                                                                       | 0.8VDD                |      | V <sub>DD</sub>      | V  |
|         | VIH3             | $P20 \sim P27$ AV <sub>REF</sub> = V <sub>DD</sub>                   |                                                                                                       | 0.7AV <sub>REF</sub>  |      | AVREF                | V  |
| 输入电压,低  | VIL1             |                                                                      | P02, P12, P13, P15, P40 ~ P47, P50 ~ P57, P63 ~ P67, P121 ~ P124, P144, P145                          |                       |      | 0.3V <sub>DD</sub>   | V  |
|         | V <sub>IL2</sub> | P00, P01, P03 ~ P06, P10<br>P30 ~ P33, P60 ~ P62, P<br>~ P143, RESET | , , , -, ,                                                                                            | 0                     |      | 0.2V <sub>DD</sub>   | V  |
|         | VIL3             | P20 ~ P27                                                            | AVREF = VDD                                                                                           | 0                     |      | 0.3AV <sub>REF</sub> | V  |
| 输出电压, 高 | Vон1             | $P00 \sim P06, P10 \sim P17, \\ P30 \sim P33, P40 \sim P47,$         | $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$<br>$I_{OH1} = -3.0 \text{ mA}$                   | V <sub>DD</sub> - 0.7 |      |                      | V  |
|         |                  | P50 ~ P57, P64 ~ P67,<br>P70 ~ P77, P120, P130,                      | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V},$<br>$I_{OH1} = -2.5 \text{ mA}$                     | V <sub>DD</sub> - 0.5 |      |                      | V  |
|         |                  | P140 ∼ P145                                                          | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V},$<br>$I_{OH1} = -1.0 \text{ mA}$                     | V <sub>DD</sub> - 0.5 |      |                      | V  |
|         | V <sub>OH2</sub> | P20 ∼ P27                                                            | AVREF = VDD,<br>IOH2 = $-100 \mu$ A                                                                   | V <sub>DD</sub> - 0.5 |      |                      | V  |
|         |                  | P121 ~ P124                                                          | Іон2 = -100 μΑ                                                                                        | V <sub>DD</sub> - 0.5 |      |                      | V  |
| 输出电压,低  | V <sub>OL1</sub> | $P00 \sim P06, P10 \sim P17, \\ P30 \sim P33, P40 \sim P47,$         | $4.0 \text{ V} \le \text{V}_{\text{DD}} \le 5.5 \text{ V},$<br>IoL1 = 8.5  mA                         |                       |      | 0.7                  | V  |
|         |                  | P50 ~ P57, P64 ~ P67,<br>P70 ~ P77, P120, P130,<br>P140 ~ P145       | $2.7 \text{ V} \le \text{V}_{\text{DD}} < 4.0 \text{ V},$<br>$\text{I}_{\text{OL1}} = 5.0 \text{ mA}$ |                       |      | 0.7                  | V  |
|         |                  |                                                                      | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V},$ Iон1 = 2.0 mA                                      |                       |      | 0.5                  | V  |
|         |                  |                                                                      | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V},$<br>$I_{OL1} = 0.5 \text{ mA}$                      |                       |      | 0.4                  | V  |
|         | V <sub>OL2</sub> | P20 ~ P27                                                            | AVREF = VDD,<br>IOL2 = 0.4 mA                                                                         |                       |      | 0.4                  | V  |
|         |                  | P121 ~ P124                                                          | Iон2 = 0.4 mA                                                                                         |                       |      | 0.4                  | V  |
|         | Vol3             | P60 ∼ P63                                                            | $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$<br>$\text{I}_{OL1} = 15.0 \text{ mA}$            |                       |      | 2.0                  | V  |
|         |                  |                                                                      | $4.0 \text{ V} \le \text{V}_{DD} \le 5.5 \text{ V},$ $I_{OL1} = 5.0 \text{ mA}$                       |                       |      | 0.4                  | V  |
|         |                  |                                                                      | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V},$ $\text{I}_{OL1} = 3.0 \text{ mA}$                  |                       |      | 0.4                  | V  |
|         |                  |                                                                      | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V},$ $I_{DL1} = 2.0 \text{ mA}$                         |                       |      | 0.4                  | V  |

# DC 特性 (3/4)

(TA =  $-40 \sim +85$ °C, 1.8 V  $\leq$  VDD = EVDD  $\leq$  5.5 V, AVREF  $\leq$  VDD, Vss = EVss = AVss = 0 V)

| 参数         | 符号    | 条件                                                                                                                                                       | 牛                                                          |             | MIN.               | TYP. | MAX.               | 单位 |
|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|-------------|--------------------|------|--------------------|----|
| 输入漏电流, 高   | Ішн1  | P00 $\sim$ P06, P10 $\sim$ P17,<br>P30 $\sim$ P33, P40 $\sim$ P47,<br>P50 $\sim$ P57, P60 $\sim$ P67,<br>P70 $\sim$ P77, P120, P130,<br>P140 $\sim$ P145 | VI = VDD                                                   |             |                    |      | 1                  | μΑ |
|            | ILIH2 | P20 ∼ P27                                                                                                                                                | Vı = AVRI                                                  | F = VDD     |                    |      | 1                  | μА |
|            | Ішнз  | P121 ~ 124                                                                                                                                               | Vı = Vdd                                                   | I/O 端口模式    |                    |      | 1                  | μΑ |
|            |       | (X1, X2, XT1, XT2)                                                                                                                                       |                                                            | OSC 模式      |                    |      | 20                 | μΑ |
| 输入漏电流,低    | ILIL1 | $P00 \sim P06, P10 \sim P17, \\ P30 \sim P33, P40 \sim P47, \\ P50 \sim P57, P60 \sim P67, \\ P70 \sim P77, P120, P130, \\ P140 \sim P145$               | 3, P40 $\sim$ P47,<br>7, P60 $\sim$ P67,<br>7, P120, P130, |             |                    |      | -1                 | μΑ |
|            | ILIL2 | P20 ∼ P27                                                                                                                                                | Vı = Vss,                                                  | AVREF = VDD |                    |      | -1                 | μА |
|            | ILIL3 | P121 ~ 124                                                                                                                                               | Vı = Vss                                                   | I/O 端口模式    |                    |      | -1                 | μΑ |
|            |       | (X1, X2, XT1, XT2)                                                                                                                                       |                                                            | OSC 模式      |                    |      | -20                | μА |
| 上拉电阻       | Rυ    | VI = VDD                                                                                                                                                 |                                                            |             | 10                 | 20   | 100                | kΩ |
| FLMD0 供电电压 | VIL   | 正常操作模式                                                                                                                                                   | E常操作模式                                                     |             | 0                  |      | 0.2V <sub>DD</sub> | ٧  |
|            | VIH   | 自编程模式                                                                                                                                                    |                                                            |             | 0.8V <sub>DD</sub> |      | V <sub>DD</sub>    | ٧  |

#### DC 特性 (4/4)

#### $(T_A = -40 \sim +85^{\circ}C, 1.8 \text{ V} \leq V_{DD} = EV_{DD} \leq 5.5 \text{ V}, AV_{REF} \leq V_{DD}, V_{SS} = EV_{SS} = AV_{SS} = 0 \text{ V})$

| 参数          | 符号                  |                                                                      | 条件                                                                                              | MIN. | TYP. | MAX. | 单位 |
|-------------|---------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------|------|------|----|
| 供电电流        | IDD1 <sup>往1</sup>  | 操作模式                                                                 | fxн = 20 MHz <sup>推 2</sup> , VDD = 5.0 V                                                       |      | 4.7  | 5.8  | mA |
|             |                     |                                                                      | $f_{XH} = 10 \text{ MHz}^{\frac{1}{2}, 3}, V_{DD} = 5.0 \text{ V}$                              |      | 2.5  | 3.5  | mA |
|             |                     |                                                                      | $f_{XH} = 10 \text{ MHz} \stackrel{\text{de 2, 3}}{\sim}, V_{DD} = 3.0 \text{ V}$               |      | 2.1  | 3.1  | mA |
|             |                     |                                                                      | $f_{XH} = 5 \text{ MHz} \stackrel{\text{tt 2, 3}}{}, V_{DD} = 3.0 \text{ V}$                    |      | 1.5  | 2.2  | mA |
|             |                     |                                                                      | $f_{XH} = 5 \text{ MHz} \stackrel{\text{te 2, 3}}{}, V_{DD} = 2.0 \text{ V}$                    |      | 1.2  | 1.8  | mA |
|             |                     |                                                                      | $f_{RH} = 8 \text{ MHz}, V_{DD} = 5.0 \text{ V}$                                                |      | 1.9  | 2.7  | mA |
|             |                     |                                                                      | $f_{SUB} = 32.768 \text{ kHz}^{\frac{11}{2}, 4}, \text{ Vdd} = 5.0 \text{ V}$                   |      | 17   | 30   | μА |
|             | IDD2 <sup>推 5</sup> | HALT 模式                                                              | fxH = 20 MHz <sup>26 2</sup> , V <sub>DD</sub> = 5.0 V                                          |      | 2.2  | 2.6  | mA |
|             |                     |                                                                      | $f_{XH} = 10 \text{ MHz}^{\frac{1}{2}, 3}, \text{ Vdd} = 5.0 \text{ V}$                         |      | 1.0  | 1.2  | mA |
|             |                     |                                                                      | fxH = 5 MHz <sup>2 2, 3</sup> , VDD = 3.0 V                                                     |      | 0.55 | 0.65 | mA |
|             |                     |                                                                      | $f_{RH} = 8 MHz$ , $V_{DD} = 5.0 V$                                                             |      | 0.6  | 0.65 | mA |
|             |                     |                                                                      | $f_{SUB} = 32.768 \text{ kHz} \stackrel{\text{$\& 2, 4}}{\sim}, \text{ V}_{DD} = 5.0 \text{ V}$ |      | 3.5  | 20   | μΑ |
|             | IDD3 <sup>推5</sup>  | STOP 模式                                                              | V <sub>DD</sub> = 5.0 V                                                                         |      | 1    | 20   | μА |
| A/D 转换器操作电流 | IADC <sup>独 6</sup> | 以最大速率转换期                                                             | 间                                                                                               |      | 0.86 | 1.9  | mA |
|             |                     | $2.3 \text{ V} \leq \text{AV}_{\text{REF}} \leq \text{V}_{\text{D}}$ | מפ                                                                                              |      |      |      |    |
| 看门狗定时器操作电流  | I <sub>WDT</sub>    | 240 kHz 内部低速                                                         | 240 kHz 内部低速振荡时钟操作期间                                                                            |      | 5    | 10   | μA |
| LVI操作电流     | ILVI <sup>注 8</sup> |                                                                      |                                                                                                 |      | 9    | 35   | μΑ |

- 注: 1. 流入内部供电电源的总电流 (VDD),包括外部操作电流 (但不包括流入端口上拉电阻和 A/D 转换器的电流)。
  - 2. 方波输入
  - 3. 当 AMPH (时钟操作模式选择寄存器(OSCCTL)的第 0 位) = 0.
  - 4. 当停止主系统时钟操作时
  - **5.** 流入内部供电电源的总电流 (VDD),包括外部操作电流 (但不包括流入端口上拉电阻、A/D 转换器、看门狗 定时器和 LVI 电路的电流)。
  - **6.** 仅流入 A/D 转换器的电流。当 A/D 转换器在操作模式或 HALT 模式下工作时,78K0/KF2 的电流值为 loo<sub>1</sub> 或 loo<sub>2</sub> 与 laoc 的和。
  - 7. 仅流入看门狗定时器的电流。当看门狗定时器在 HALT 模式或 STOP 模式下工作时,78K0/KF2 的电流值为 lop2 或 lop3 与 lwdt 的和。
  - **8.** 仅流入 LVI 电路的电流。当 LVI 电路在 HALT 模式或 STOP 模式下工作时,78K0/KF2 的电流值为 IDD2 或 IDD3 与 ILVI 的和。

备注: 1. fxH: 高速系统时钟频率 (X1 时钟振荡频率或外部主系统时钟频率)

2. fr.H: 内部高速振荡时钟频率

3. fsua: 子系统时钟频率 (XT1 时钟振荡频率或外部子系统时钟频率)

# AC 特性

## (1) 基本操作

(TA =  $-40 \sim +85^{\circ}$ C, 1.8 V  $\leq$  VDD = EVDD  $\leq$  5.5 V, AVREF  $\leq$  VDD, VSS = EVSS = AVSS = 0 V)

| 参数                                           | 符号               | 条件                                                         |                                                           | MIN.                                    | TYP.   | MAX. | 单位  |
|----------------------------------------------|------------------|------------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------|--------|------|-----|
| 指令周期 (指令最短执行时间)                              | Тсч              | 主系统时钟 (fxp)操作                                              | $4.0~V \leq V_{DD} \leq 5.5~V$                            | 0.1                                     |        | 32   | μS  |
|                                              |                  |                                                            | $2.7 \text{ V} \leq \text{V}_{\text{DD}} < 4.0 \text{ V}$ | 0.2                                     |        | 32   | μS  |
|                                              |                  |                                                            | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V}$         | 0.4 <sup>2 1</sup>                      |        | 32   | μS  |
|                                              |                  | 子系统时钟 (fsua) 操作                                            |                                                           | 114                                     | 122    | 125  | μS  |
| 外部主系统时钟频率                                    | fexclk           | $4.0~\text{V} \leq \text{V}_{\text{DD}} \leq 5.5~\text{V}$ |                                                           | 1.0                                     |        | 20.0 | MHz |
|                                              |                  | 2.7 V ≤ V <sub>DD</sub> < 4.0 V                            |                                                           | 1.0                                     |        | 10.0 | MHz |
|                                              |                  | 1.8 V ≤ V <sub>DD</sub> < 2.7 V                            |                                                           | 1.0                                     |        | 5.0  | MHz |
| 外部主系统时钟输入高电平宽度,<br>低电平宽度                     | texclkh,         |                                                            |                                                           | (1/fexclx<br>× 1/2) – 1                 |        |      | ns  |
| 外部子系统时钟频率                                    | fexclks          |                                                            |                                                           | 32                                      | 32.768 | 35   | kHz |
| 外部子系统时钟输入高电平宽度、<br>低电平宽度                     | texclksh,        |                                                            |                                                           | (1/fexcuss<br>× 1/2) – 5                |        |      | ns  |
| Tl000, Tl010, Tl001, Tl011 输入高<br>电平宽度、低电平宽度 | tтіно,<br>tтіLo  | $4.0 \text{ V} \le \text{Vdd} \le 5.5 \text{ V}$           |                                                           | 2/f <sub>sam</sub> + 0.1 <sup>挂 2</sup> |        |      | μS  |
|                                              |                  | 2.7 V ≤ V <sub>DD</sub> < 4.0 V                            |                                                           | 2/f <sub>sam</sub> + 0.2 <sup>推2</sup>  |        |      | μS  |
| TI50, TI51 输入频率                              | f <sub>TI5</sub> | $4.0~\text{V} \leq \text{V}_{\text{DD}} \leq 5.5~\text{V}$ |                                                           |                                         |        | 10   | MHz |
|                                              |                  | 2.7 V ≤ V <sub>DD</sub> < 4.0 V                            |                                                           |                                         |        | 10   | MHz |
|                                              |                  | 1.8 V ≤ V <sub>DD</sub> < 2.7 V                            |                                                           |                                         |        | 5    | MHz |
| TI50, TI51 输入高电平宽度、低电                        | <b>t</b> тін5,   | $4.0~\text{V} \leq \text{V}_{\text{DD}} \leq 5.5~\text{V}$ |                                                           | 50                                      |        |      | ns  |
| 平宽度                                          | <b>t</b> TIL5    | 2.7 V ≤ V <sub>DD</sub> < 4.0 V                            |                                                           | 50                                      |        |      | ns  |
|                                              |                  | 1.8 V ≤ V <sub>DD</sub> < 2.7 V                            |                                                           | 100                                     |        |      | ns  |
| 中断输入高电平宽度、低电平宽度                              | tinth,           |                                                            |                                                           | 1                                       |        |      | μS  |
|                                              | tintl            |                                                            |                                                           |                                         |        |      |     |
| 按键中断输入低电平宽度                                  | <b>t</b> kr      |                                                            |                                                           | 250                                     |        |      | ns  |
| RESET低电平宽度                                   | trsL             |                                                            |                                                           | 10                                      |        |      | μS  |

# **注:** 1. 当使用 8 MHz 内部振荡器时为 0.38 μs。

**2.** 使用预分频模式寄存器 00 和 01 (PRM00、PRM01) 的第 0 和 1 位 (PRM000、PRM001 或 PRM010、PRM011) 可以选择 fsam = fprs, fprs/4, fprs/256 或 fprs, fprs/16, fprs/64。注意,当选择 TI000 或 TI001 的 有效沿作为计数时钟时,fsam = fprs。

## Tcy vs. Vdd (主系统时钟操作)



## AC 时序测试点 (外部主系统时钟和外部子系统时钟除外)



#### 外部主系统时钟时序、外部子系统时钟时序



## TI 时序





## 中断请求输入时序



## 按键中断输入时序



# RESET 输入时序



#### (2) 串行接口

(TA =  $-40 \sim +85$ °C, 1.8 V  $\leq$  VDD = EVDD  $\leq$  5.5 V, AVREF  $\leq$  VDD, Vss = EVss = AVss = 0 V)

## (a) UART6 (专用波特率发生器输出)

| 参数   | 符号 | 条件 | MIN. | TYP. | MAX.  | 单位   |
|------|----|----|------|------|-------|------|
| 传送速率 |    |    |      |      | 312.5 | kbps |

#### (b) UART0 (专用波特率发生器输出)

| 参数   | 符号 | 条件 | MIN. | TYP. | MAX.  | 单位   |
|------|----|----|------|------|-------|------|
| 传送速率 |    |    |      |      | 312.5 | kbps |

## (c) IIC0

| 参数                           | 符号      | 标准模式 |      | 高速   | 模式   | 单位  |
|------------------------------|---------|------|------|------|------|-----|
|                              |         | MIN. | MAX. | MIN. | MAX. |     |
| SCL0 时钟频率                    | fscL    | 0    | 100  | 0    | 400  | kHz |
| 启动/重新启动条件的建立时间 <sup>±1</sup> | tsu:sta | 4.8  | -    | 0.7  | -    | μS  |
| 保持时间                         | thd:sta | 4.1  | ı    | 0.7  | -    | μS  |
| 当 SCL0 = "L"时的保持时间           | tLOW    | 5.0  | i    | 1.25 | -    | μS  |
| 当 SCL0 = "H"时的保持时间           | tHIGH   | 5.0  | -    | 1.25 | -    | μS  |
| 数据建立时间 (接收)                  | tSU:DAT | 0    | -    | 0    | -    | μS  |
| 数据保持时间 (发送) <sup>#2</sup>    | tHD:DAT | 0.47 | 4.0  | 0.23 | 1.00 | μS  |

注: 1. 当检测到启动/重新启动条件时在经历了该周期时间后产生第一个时钟脉冲。

2. tHD:DAT 的最大值(MAX.)是在正常传送期间,在 ACK (应答)时序中插入一个等待状态。

# (d) CSI1n (主设备模式, SCK1n... 内部时钟输出)

| 参数                                 | 符号            | 条件                                                         | MIN.                | TYP. | MAX. | 单位 |
|------------------------------------|---------------|------------------------------------------------------------|---------------------|------|------|----|
| SCK1n 周期时间                         | tkcY1         | $4.0~\text{V} \leq \text{V}_{\text{DD}} \leq 5.5~\text{V}$ | 100                 |      |      | ns |
|                                    |               | $2.7 \text{ V} \le \text{V}_{DD} < 4.0 \text{ V}$          | 200                 |      |      | ns |
|                                    |               | $1.8 \text{ V} \le \text{V}_{DD} < 2.7 \text{ V}$          | 400                 |      |      | ns |
| SCK1n 高/低电平宽度                      | tкн1,<br>tкL1 |                                                            | tксү1/2 – 10<br>¥±1 |      |      | ns |
| SI1n 建立时间 (到 SCK1n↑)               | tsıkı         |                                                            | 30                  |      |      | ns |
| SI1n 保持时间 (从 SCK1n1)               | tksi1         |                                                            | 30                  |      |      | ns |
| 从 <del>SCK1n</del> ↓到 SO1n 输出的延迟时间 | tkso1         | C = 50 pF ** 2                                             |                     |      | 40   | ns |

注: 1. 使用高速系统时钟 (fxH) 时的取值

**2.** C是 SCK1n 和 SO1n 输出线的负载电容。

# (e) CSI1n (从设备模式, SCK1n... 外部时钟输入)

| 参数                                 | 符号                 | 条件           | MIN.    | TYP. | MAX. | 单位 |
|------------------------------------|--------------------|--------------|---------|------|------|----|
| SCK1n 周期                           | tKCY2              |              | 400     |      |      | ns |
| SCK1n 高/低电平宽度                      | t <sub>KH2</sub> , |              | tkcy2/2 |      |      | ns |
|                                    | t <sub>KL2</sub>   |              |         |      |      |    |
| Sl1n 建立时间 (至 SCK1n↑)               | tsik2              |              | 80      |      |      | ns |
| SI1n 保持时间 (从 SCK1n↑)               | tksi2              |              | 50      |      |      | ns |
| 从 <del>SCK1n</del> ↓ 到 SO1n 输出的延迟时 | <b>t</b> KSO2      | C = 50 pF ** |         |      | 120  | ns |
| 间                                  |                    |              |         |      |      |    |

注: C是SOIn输出线的负载电容。

**备注:** n = 0, 1

# (f) CSIA0 (主设备模式, SCKA0...内部时钟输出)

| 参数                             | 符号            |                                            | 条件                              | MIN.             | TYP. | MAX.           | 单位 |
|--------------------------------|---------------|--------------------------------------------|---------------------------------|------------------|------|----------------|----|
| SCKA0 周期                       | tксүз         | $4.0 \text{ V} \leq V_{DD} \leq 5.$        | 5 V                             | 600              |      |                | ns |
|                                |               | 2.7 V ≤ V <sub>DD</sub> < 4.               | 0 V                             | 1200             |      |                | ns |
| SCKAO 高/低电平宽度                  | tкнз,<br>tкLз | $4.0 \text{ V} \leq \text{V}_{DD} \leq 5.$ | 5 V                             | tксүз/2 –<br>50  |      |                | ns |
|                                |               | 2.7 V ≤ V <sub>DD</sub> < 4.               | 0 V                             | tксүз/2 –<br>100 |      |                | ns |
| SIA0 建立时间 (至 SCKAO↑)           | tsik3         |                                            |                                 |                  |      |                | ns |
| SIA0 保持时间 (从 SCKAO↑)           | tksi3         |                                            |                                 | 300              |      |                | ns |
| 从 SCKAO↓ 到 SOAO 输出的延 tkso3 时时间 | tkso3         | C = 100 pF <sup>注</sup>                    | 4.0 V ≤ V <sub>DD</sub> ≤ 5.5 V |                  |      | 200            | ns |
|                                |               |                                            | 2.7 V ≤ V <sub>DD</sub> < 4.0 V |                  |      | 300            | ns |
| 从 SCKA0个到 STB0个的时间             | tsbd          |                                            |                                 | tксүз/2 – 100    |      |                | ns |
| 选通信号高电平宽度                      | tssw          | $4.0 \text{ V} \leq \text{V}_{DD} \leq 5.$ | 5 V                             | tксүз –<br>30    |      |                | ns |
|                                |               | 2.7 V ≤ V <sub>DD</sub> < 4.               | 2.7 V ≤ V <sub>DD</sub> < 4.0 V |                  |      |                | ns |
| 忙信号建立时间 (到忙信号检测时序)             | tBYS          |                                            |                                 | 100              |      |                | ns |
| 忙信号保持时间 (从忙信号检测                | tвүн          | $4.0 \text{ V} \leq \text{V}_{DD} \leq 5.$ | 5 V                             | 100              |      |                | ns |
| 时序)                            |               | 2.7 V ≤ V <sub>DD</sub> < 4.               | 2.7 V ≤ V <sub>DD</sub> < 4.0 V |                  |      |                | ns |
| 从忙信号不活动到 SCKAO↓的时间             | tsps          |                                            |                                 |                  |      | <b>2t</b> ксүз | ns |

注: C是 SCKAO 和 SOAO 输出线的负载电容。

# (g) CSIA0 (从模式, SCKAO...外部时钟输入)

| 参数                   | 符号                                | 条件                             |                                                    | MIN. | TYP. | MAX. | 单位 |
|----------------------|-----------------------------------|--------------------------------|----------------------------------------------------|------|------|------|----|
| SCKA0 周期             | tkcy4                             | $4.0~V \leq V_{DD} \leq 5.5~V$ |                                                    | 600  |      |      | ns |
|                      |                                   | 2.7 V ≤ V <sub>DD</sub> < 4.0  | 0 V                                                | 1200 |      |      | ns |
| SCKAO 高/低电平宽度        | <b>t</b> кн4,                     | $4.0~V \leq V_{DD} \leq 5.5~V$ |                                                    | 300  |      |      | ns |
|                      | tkl4                              | 2.7 V ≤ V <sub>DD</sub> < 4.0  | 0 V                                                | 600  |      |      | ns |
| SIA0 建立时间 (到 SCKAO↑) | tsık4                             |                                |                                                    | 100  |      |      | ns |
| SIA0 保持时间 (从 SCKA0↑) | tksi4                             |                                |                                                    | 300  |      |      | ns |
| 从 SCKAO↓到 SOAO 输出的延  | tkso4                             | C = 100 pF 注                   | $4.0~V \leq V_{DD} \leq 5.5~V$                     |      |      | 200  | ns |
| 时时间                  |                                   |                                | $2.7 \text{ V} \leq \text{V}_{DD} < 4.0 \text{ V}$ |      |      | 300  | ns |
| SCKA0 上升/下降时间        | t <sub>R4</sub> , t <sub>F4</sub> |                                |                                                    |      |      | 1000 | ns |

注 C是SOAO输出线的负载电容。

## 串行传送时序 (1/2)

## IIC0:



## CSI1n:



**备注:** m = 1, 2 n = 0, 1

# 串行传送时序 (2/2)

# CSIA0:



# CSIA0 (忙处理):



注: 这里 SCKAO 并没有变为低电平,图中的显示是为了描述时序规范。

#### A/D 转换器特性

## (TA = $-40 \sim +85$ °C, 1.8 V $\leq$ VDD = EVDD $\leq$ 5.5 V, 2.3 V $\leq$ AVREF $\leq$ VDD, Vss = EVss = AVss = 0 V)

| 参数                    | 符号                       | 条件                                                           | MIN. | TYP. | MAX.  | 单位   |
|-----------------------|--------------------------|--------------------------------------------------------------|------|------|-------|------|
| 分辨率                   | Res                      |                                                              |      |      | 10    | bit  |
| 总误差 <sup>推1,2</sup>   | Ainl                     | $4.0~\text{V} \leq \text{AV}_{\text{REF}} \leq 5.5~\text{V}$ |      |      | ±0.4  | %FSR |
|                       |                          | $2.7 \text{ V} \leq \text{AV}_{\text{REF}} < 4.0 \text{ V}$  |      |      | ±0.6  | %FSR |
|                       |                          | $2.3 \text{ V} \leq \text{AV}_{\text{REF}} < 2.7 \text{ V}$  |      |      | ±1.2  | %FSR |
| 转换时间                  | tconv                    | $4.0~\text{V} \leq \text{AV}_{\text{REF}} \leq 5.5~\text{V}$ | 6.1  |      | 36.7  | μs   |
|                       |                          | $2.7 \text{ V} \leq \text{AV}_{\text{REF}} < 4.0 \text{ V}$  | 12.2 |      | 36.7  | μs   |
|                       |                          | $2.3 \text{ V} \leq \text{AV}_{\text{REF}} < 2.7 \text{ V}$  | 27   |      | 66.6  | μS   |
| 零度误差 <sup>±1,2</sup>  | Ezs                      | $4.0~\text{V} \leq \text{AV}_{\text{REF}} \leq 5.5~\text{V}$ |      |      | ±0.4  | %FSR |
|                       |                          | $2.7 \text{ V} \leq \text{AV}_{\text{REF}} < 4.0 \text{ V}$  |      |      | ±0.6  | %FSR |
|                       | 2.3 V ≤ AV <sub>RI</sub> | 2.3 V ≤ AVREF < 2.7 V                                        |      |      | ±0.6  | %FSR |
| 满度误差 生1,2             | Ers                      | $4.0~\text{V} \leq \text{AV}_{\text{REF}} \leq 5.5~\text{V}$ |      |      | ±0.4  | %FSR |
|                       |                          | $2.7 \text{ V} \leq \text{AV}_{\text{REF}} < 4.0 \text{ V}$  |      |      | ±0.6  | %FSR |
|                       |                          | 2.3 V ≤ AVREF < 2.7 V                                        |      |      | ±0.6  | %FSR |
| 积分非线性误差 <sup>±1</sup> | ILE                      | $4.0~\text{V} \leq \text{AV}_{\text{REF}} \leq 5.5~\text{V}$ |      |      | ±2.5  | LSB  |
|                       |                          | $2.7 \text{ V} \leq \text{AV}_{\text{REF}} < 4.0 \text{ V}$  |      |      | ±4.5  | LSB  |
|                       |                          | $2.3 \text{ V} \leq \text{AV}_{\text{REF}} < 2.7 \text{ V}$  |      |      | ±6.5  | LSB  |
| 微分非线性误差 <sup>±1</sup> | DLE                      | $4.0~\text{V} \leq \text{AV}_{\text{REF}} \leq 5.5~\text{V}$ |      |      | ±1.5  | LSB  |
|                       |                          | $2.7 \text{ V} \le \text{AVREF} < 4.0 \text{ V}$             |      |      | ±2.0  | LSB  |
|                       |                          | 2.3 V ≤ AVREF < 2.7 V                                        |      |      | ±2.0  | %FSR |
| 模拟输入电压                | Vain                     |                                                              | AVss |      | AVREF | V    |

# 注: 1. 不包括量化误差 (±1/2 LSB)

2. 该值表示满度的百分比 (%FSR)

# 1.59 V POC 电路特性(T<sub>A</sub> = −40 ~ +85°C, Vss = EVss = 0 V)

| 参数        | 符号           | 条件                                                 | MIN. | TYP. | MAX. | 单位   |
|-----------|--------------|----------------------------------------------------|------|------|------|------|
| 检测电压      | VPOC         |                                                    | 1.44 | 1.59 | 1.74 | V    |
| 供电电压的上升斜率 | <b>t</b> ртн | V <sub>DD</sub> : 0 V → 变到 V <sub>P</sub> OC 的指定电压 |      |      | 0.5  | V/ms |
| 最小脉冲宽度    | tpw          |                                                    | 200  |      |      | μS   |

# POC 电路时序



# 供电电压上升时间 (TA = $-40 \sim +85$ °C, Vss = EVss = 0 V)

| 参数                                                                                | 符号            | 条件                                     | MIN. | TYP. | MAX. | 单位 |
|-----------------------------------------------------------------------------------|---------------|----------------------------------------|------|------|------|----|
| 上升至 1.8 V (V <sub>DD</sub> (MIN.))所需的最长时间 (V <sub>DD</sub> : 0 V → 1.8 V)         | tpup1         | 当没有使用 RESET 输入时,<br>POCMODE (选项字节) = 0 |      |      | 3.6  | ms |
| 上升至 1.8 V (V <sub>DD</sub> (MIN.))所需的最长时间 (释放 RESET 输入 → V <sub>DD</sub> : 1.8 V) | <b>t</b> PUP2 | 当使用 RESET 输入时,<br>POCMODE (选项字节) = 0   |      |      | 1.9  | ms |

## 供电电压上升时间时序

● 当没有使用 RESET 引脚输入时

●当使用 RESET 引脚输入时



# 2.7 V POC 电路特性(TA = -40 ~ +85°C, Vss = EVss = 0 V)

| 参数           | 符号     | 条件                 | MIN. | TYP. | MAX. | 单位       |
|--------------|--------|--------------------|------|------|------|----------|
| 供电电压应用中的检测电压 | VDDPOC | POCMODE (选项字节) = 1 | 2.50 | 2.70 | 2.90 | <b>V</b> |

LVI 电路特性(TA = -40  $\sim$  +85°C, VPOC  $\leq$  VDD = EVDD  $\leq$  5.5 V, AVREF  $\leq$  VDD, Vss = EVss = 0 V)

| 参数    |                      | 符号                  | 条件                                              | MIN. | TYP. | MAX. | 单位 |
|-------|----------------------|---------------------|-------------------------------------------------|------|------|------|----|
| 检测电压  | 供电电压电平               | VLVIO               |                                                 | 4.14 | 4.24 | 4.34 | V  |
|       |                      | V <sub>LVI1</sub>   |                                                 | 3.99 | 4.09 | 4.19 | V  |
|       |                      | V <sub>LVI2</sub>   |                                                 | 3.83 | 3.93 | 4.03 | V  |
|       |                      | V <sub>LVI3</sub>   |                                                 | 3.68 | 3.78 | 3.88 | V  |
|       |                      | V <sub>LVI4</sub>   |                                                 | 3.52 | 3.62 | 3.72 | V  |
|       |                      | V <sub>LVI5</sub>   |                                                 | 3.37 | 3.47 | 3.57 | V  |
|       |                      | V <sub>L</sub> VI6  |                                                 | 3.22 | 3.32 | 3.42 | V  |
|       |                      | V <sub>LVI7</sub>   |                                                 | 3.06 | 3.16 | 3.26 | V  |
|       |                      | V <sub>LVI8</sub>   |                                                 | 2.91 | 3.01 | 3.11 | V  |
|       |                      | V <sub>LVI9</sub>   |                                                 | 2.75 | 2.85 | 2.95 | V  |
|       |                      | V <sub>L</sub> VI10 |                                                 | 2.60 | 2.70 | 2.80 | V  |
|       |                      | V <sub>LVI11</sub>  |                                                 | 2.45 | 2.55 | 2.65 | V  |
|       |                      | V <sub>LVI12</sub>  |                                                 | 2.29 | 2.39 | 2.49 | V  |
|       |                      | V <sub>L</sub> VI13 |                                                 | 2.14 | 2.24 | 2.34 | V  |
|       |                      | V <sub>LVI14</sub>  |                                                 | 1.98 | 2.08 | 2.18 | V  |
|       |                      | V <sub>LVI15</sub>  |                                                 | 1.83 | 1.93 | 2.03 | V  |
|       | 外部输入引脚 <sup>±1</sup> | EXLVI               | EXLVI < $V_{DD}$ , 1.8 $V \le V_{DD} \le 5.5 V$ |      | 1.21 |      | V  |
| 最短脉冲宽 | 度                    | tuw                 |                                                 | 200  |      |      | μS |
| 操作稳定等 | 待时间 <sup>推 2</sup>   | tlwait              |                                                 |      |      | 10   | μS |

## 注: 1. 使用 EXLVI/P120/INTP0 引脚

2. 从设置低电压检测寄存器(LVIM)的第7位(LVION)=1到操作稳定所需的时间。

备注: VLVI(n-1) > VLVIn: n = 1 ~ 15

## LVI 电路时序



# 数据存储器在 STOP 模式下低供电电压时的数据保持特性 (TA = $-40 \sim +85$ °C)

| 参数       | 符号    | 条件 | MIN.              | TYP. | MAX. | 单位 |
|----------|-------|----|-------------------|------|------|----|
| 数据保持供电电压 | VDDDR |    | 1.44 <sup>2</sup> |      | 5.5  | V  |

注: 该值根据 POC 检测电压而变化。当电压降低时,一直保持该数据直至 POC 复位有效,但当 POC 复位有效时数据不能保持。



#### 闪存编程特性

(TA =  $-40 \sim +85$ °C, 2.7 V  $\leq$  VDD = EVDD  $\leq$  5.5 V, AVREF  $\leq$  VDD, VSS = EVSS = AVSS = 0 V)

## (1) 基本特性

| 参                    | 数     | 符号              | 条件                                                 | MIN. | TYP. | MAX. | 单位 |
|----------------------|-------|-----------------|----------------------------------------------------|------|------|------|----|
| V <sub>DD</sub> 供电电流 |       | I <sub>DD</sub> | fxp = 10 MHz (TYP.), 20 MHz (MAX.)                 |      | 4.5  | 11.0 | mA |
| 擦除时间 <sup>推1</sup>   | 所有存储块 | Teraca          |                                                    |      | 20   | 200  | ms |
|                      | 块单元   | Terasa          |                                                    |      | 20   | 200  | ms |
| 写时间                  |       | Twrwa           |                                                    |      | TBD  | TBD  | μS |
| 每片重写次数               |       | Сегwг           | 保持时间: 10 年<br>擦除 1 次 +擦除后写 1 次= 1 次重写 <sup>2</sup> | 100  |      |      | 次  |

注: 1. 不包括擦除前的预写时间和擦除验证时间 (写回时间)

**2.** 在出货后第一次对产品进行写操作时,"擦除  $\rightarrow$  写"和"只写"作为一次重写。

**备注:** fxp: 主系统时钟振荡频率

## (2) 串行写操作特性

| 参数                                   | 符号                             | 条件 | MIN.      | TYP. | MAX. | 单位 |
|--------------------------------------|--------------------------------|----|-----------|------|------|----|
| 从 RESET <sup>1</sup> 到 FLMD0 计数开始的时间 | TRFCF                          |    | 4.1       |      | 17.1 | ms |
| 计数执行时间                               | TCOUNT                         |    | 10.8      |      | 13.2 | ms |
| FLMD0 计数器高/低电平宽度                     | TcH/TcL                        |    | Tc × 0.45 |      |      | μS |
| FLMD0 计数器上升/下降时间                     | T <sub>R</sub> /T <sub>F</sub> |    | 12.5      |      |      | μS |

备注:评估后这些值可能会发生变化。

## 串行写操作



# 第三十一章 封装图

# \* 80 引脚塑封 LQFP(14×14)



**注:** 该结构在最大使用材料情况下,每条引脚的中心线位于其实际位置的 0.13mm 内

|    | (UNIT:mm)    |
|----|--------------|
| 项目 | 尺寸           |
| D  | 14.00±0.20   |
| Е  | 14.00±0.20   |
| HD | 17.20±0.20   |
| HE | 17.20±0.20   |
| Α  | 1.70 MAX.    |
| A1 | 0.125±0.075  |
| A2 | 1.40±0.05    |
| A3 | 0.25         |
| b  | 0.32±0.06    |
| С  | 0.17^+0.03   |
| L  | 0.80         |
| Lp | 0.886±0.15   |
| L1 | 1.60±0.20    |
| θ  | 3°+5°        |
| е  | 0.65         |
| х  | 0.13         |
| у  | 0.10         |
| ZD | 0.825        |
| ZE | 0.825        |
|    | P80GC-65-UBT |

引脚端详图

- L1 →

АЗ

– Lp

# \* 80 引脚塑封 LQFP(密脚距)(12×12)



θ — Lp — Lp

项目

D E

HD

ΗE

Α

У

ZD

ZΕ

引脚端详图



**注:** 该结构在最大使用材料情况下,每条引脚的中心线位于其实际位置的 0.08mm 内

P80GK-50-8EU-1

(UNIT:mm)

尺寸 12.00±0.20

12.00±0.20

14.00±0.20

14.00±0.20

1.60 MAX.

0.10±0.05 1.40±0.05

 $0.145^{\,+0.055}_{\,-0.045}$ 

0.60±0.15

1.00±0.20 3°+5° -3°

0.25 0.22±0.05

0.50

0.50 0.08 0.08

1.25

1.25

# 第三十二章 等待注意事项

## 32.1 等待注意事项

本产品有两种内部系统总线。

一种是 CPU 总线,另一种是连接低速外部硬件的外设总线。

由于 CPU 总线时钟与外设总线时钟是异步的,因此如果对 CPU 的访问与对外设的访问冲突时,可能会有不期望的非法数据产生。

因此当访问可能会产生冲突的外设时, CPU 反复执行处理, 直至出现正确数据。

这样,CPU 并不执行下一条指令,而是等待。如果出现这种情况,指令执行所需的时钟数会因等待的时钟数而增加(如需了解等待时钟数的详细内容,参见表 32-1 和 32-2)。在进行实时操作时必须要注意这一点。

## 32.2 产生等待的外部硬件

表 32-1 列出了当被 CPU 访问时发出等待请求的寄存器和 CPU 等待的时钟数。表 32-2 列出了发出等待请求的 RAM 访问方式和 CPU 等待时钟数。

表 32-1 产生等待的寄存器和 CPU 等待时钟数

|               |                                                                                                                                                                                                                                                                                        | ,                   | *** *****                                                                                |  |  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------------------------------------------------------------------------------|--|--|
| 外部硬件          | 寄存器                                                                                                                                                                                                                                                                                    | 访问方式                | 等待时钟的个数                                                                                  |  |  |
| 串行接口<br>UART0 | ASIS0                                                                                                                                                                                                                                                                                  | 读                   | 1 个时钟 (恒定)                                                                               |  |  |
| 串行接口<br>UART6 | ASIS6                                                                                                                                                                                                                                                                                  | 读                   | 1 个时钟 (恒定)                                                                               |  |  |
| 串行接口 IIC0     | IICS0                                                                                                                                                                                                                                                                                  | 读                   | 1 个时钟 (恒定)                                                                               |  |  |
| A/D 转换器       | ADM                                                                                                                                                                                                                                                                                    | 写                   | $1\sim5$ 个时钟 (当选择 $f_{AD}=f_{PRS}/2$ 时)                                                  |  |  |
|               | ADS                                                                                                                                                                                                                                                                                    | 写                   | 1~7个时钟 (当选择 fad = fprs/3 时)                                                              |  |  |
|               | ADPC                                                                                                                                                                                                                                                                                   | 写                   | <ul><li>1 ~ 9 个时钟 (当选择 fab = fprs/4 时)</li><li>2 ~ 13 个时钟 (当选择 fab = fprs/6 时)</li></ul> |  |  |
|               | ADCR                                                                                                                                                                                                                                                                                   | 读                   | 2 ~ 17 个时钟 (当选择 faD = fers/8 时)<br>2 ~ 25 个时钟 (当选择 fAD = fers/12 时)                      |  |  |
|               | 上述时钟个数是指在选择相同的源时钟作为 fcpu 和 fprs. 时的值。可以根据以下表达式和条件计算等待时钟的个数。 <计算等待时钟数> ● 等待时钟数 = {(1/fad) × 2/(1/fcpu)} + 1  * 如果等待时钟的个数≤ 0.5 则将小数点以后的部分舍去,而如果等待时钟的个数> 0.5,则进行四舍五入 fad: A/D 转换时钟的频率 (fprs/2 ~ fprs/12) fcpu: CPU 时钟频率 fprs: 外部硬件时钟频率 fprs: 外部硬件时钟频率 fprs: 主系统时钟频率 <= 等待时钟的最大/最小个数所需的条件> |                     |                                                                                          |  |  |
|               | • 最大个数: CPU 的最高速                                                                                                                                                                                                                                                                       | 度(fxp),A/D 转换时钟的最低: | 速度(fprs/12)                                                                              |  |  |

• 最小个数: CPU 的最低速度(fsub/2), A/D 转换时钟的最高速度 (fprs/2)

注意事项: 当 CPU 使用子系统时钟而外部硬件时钟停止时,不要使用产生等待请求的方式访问上述寄存器。

**备注:** 这里的时钟是指 CPU 时钟(fcpu)。

638

#### 表 32-2 产生等待的 RAM 访问方式和 CPU 等待时钟数

| 次 02 2 ) 工程间的 (CAM ) 0 [7] 2 [7] 5 [7] 5 [7] |      |                      |  |  |  |
|----------------------------------------------|------|----------------------|--|--|--|
| 区域                                           | 访问方式 | 等待时钟数                |  |  |  |
| 缓冲 RAM                                       | 写    | 1~81个时钟 <sup>推</sup> |  |  |  |

<计算等待时钟数>

 $\{(1/f_W) \times 5/(1/f_{CPU})\} + 1$ 

\* 如果等待时钟的个数乘以(1/fcpu)后 $\leq$  tcpuL 则将小数点以后的部分舍去,而如果> tcpuL,则进行四舍五入。

fw: 由 CSIS0 寄存器的 CKS00 位选择的基本时钟频率 (CKS00 = 0: fprs, CKS00 = 1: fprs/2)

fcpu: CPU 时钟频率 tcpu: CPU 时钟低电平宽度 fprs: 外部硬件时钟频率

注: 如果 5 个或 5 个以上 CSIAO 操作时钟被插入到从 CSIAO 到 RAM 的写时序和从 CPU 到缓冲 RAM 的写时序之间,则不会产生等待时钟。

# 附录 A 开发工具

**78K0/KF2** 的系统开发中使用以下开发工具。 图 **A-1** 显示了开发工具的组成。

## • 支持 PC98-NX 系列

除非特别说明,IBM PC/AT $^{TM}$  兼容机支持的产品与 PC98-NX 系列计算机是兼容的。当使用 PC98-NX 系列计算机时,参阅 IBM PC/AT 兼容机的使用说明。

# • Windows<sup>TM</sup>

除非特别说明,"Windows" 是指以下几种操作系统。

- Windows 98
- Windows NT<sup>TM</sup>
- Windows 2000
- Windows XP

#### 图 A-1 开发工具的组成(1/2)

## (1) 当使用在线仿真器 QB-78K0KX2 时



- 注: 1. 软件包中不包括 C 库源文件。
  - 2. 汇编编译器中包括项目管理器 PM+。

PM+仅用于 Windows。

3. 购买在线仿真器 QB-78K0KX2 时还提供集成调试器 ID78K0-QB、简单闪存编程器 PG-FPL3,电源和 USB 接口电缆。其他产品均独立销售。

#### 图 A-1. 开发工具的组成(2/2)

## ★ (2) 当使用片上调试仿真器 QB-78K0MINI 时



- 注: 1. 软件包中不包括 C 库源文件。.
  - 2. 汇编编译器中包括项目管理器 PM+。

PM+ 仅用于 Windows。

3. 购买片上调试仿真器 QB-78K0MINI 时还提供集成调试器 ID78K0-QB、USB 接口电缆和连接电缆。其他产品均独立销售。

# A.1 软件包

| SP78K0      | 开发工具此软件包适用于 78K/0 系列。 |
|-------------|-----------------------|
| 78K/0 系列软件包 | 产品型号: μS××××SP78K0    |

**备注:** 产品型号中的××××随主机和使用的 OS 而变化。

| μS <u>××××</u> SP78K0 |      |               |               |        |
|-----------------------|------|---------------|---------------|--------|
|                       | ×××× | 主机            | os            | 存储介质   |
|                       | AB17 | PC-9800 系列    | Windows (日文版) | CD-ROM |
|                       | BB17 | IBM PC/AT 兼容机 | Windows (英文版) |        |

## A.2 语言处理软件

| RA78K0<br>汇编编译器                  | 该汇编编译器将助记符编写的程序转换为微处理器可执行的目标代码。该汇编编译器可以自动建立符号表和对转移指令进行优化。该汇编编译器应当和设备文件(DF780547) (独立销售)一起使用。 <pc ra78k0="" 环境中使用="" 的注意事项=""> 该汇编编译器是基于 DOS 应用的。它也可以在 Windows 环境下使用,但必须在 Windows 环境下使用项目管理器 (包含在汇编编译器软件包中)。</pc> |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  | 产品型号: μS××××RA78K0                                                                                                                                                                                               |
| CC78K0<br>C 编译器                  | 该编译器将C程序转换成微控制器可执行的目标代码。<br>该编译器应当和汇编程序、设备文件(二者均独立销售)结合使用。<br><pc cc78ko="" 环境中使用="" 的注意事项=""><br/>C编译器是基于 DOS 应用的。它也可以在 Windows 环境下使用,但必须在 Windows 环境下使用项目管理器(包含在汇编编译器软件包中)。</pc>                               |
|                                  | 产品型号: μS××××CC78K0                                                                                                                                                                                               |
| DF780547 <sup>推1</sup><br>设备文件   | 该文件包含设备特有的信息。<br>该设备文件应当结合工具(RA78K0、CC78K0、用于 SM+ 的 78K0/KX2 和 ID78K0-QB)<br>(均为独立销售)一起使用。<br>相应的 OS 和主机随使用工具而变化。                                                                                                |
|                                  | 产品型号: μS××××DF780547                                                                                                                                                                                             |
| CC78K0-L <sup>±2</sup><br>C 库源文件 | 这是一个函数的源文件,用来配置 C 编译器中的目标库。<br>该文件需要和用户使用规范说明中的目标库(包含在 C 编译器中)相匹配。                                                                                                                                               |
|                                  | 产品型号: μS××××CC78K0-L                                                                                                                                                                                             |

- 注: 1. DF780547 可以与 RA78K0、CC78K0、用于 SM+ 的 78K0/KX2 和 ID78K0-QB 一起使用。
  - 2. 软件包(SP78K0)不包括 CC78K0-L。

## 备注: 产品型号中的××××随主机和使用的 OS 而变化。

 $\begin{array}{l} \mu \text{S} \times \times \times \text{RA78K0} \\ \mu \text{S} \times \times \times \text{CC78K0} \\ \mu \text{S} \underline{\times \times \times} \text{CC78K0-L} \end{array}$ 

| xxxx | 主机                         | os                                | 存储介质   |
|------|----------------------------|-----------------------------------|--------|
| AB17 | PC-9800 系列                 | Windows (日文版)                     | CD-ROM |
| BB17 | IBM PC/AT兼容机               | Windows (英文版)                     |        |
| 3P17 | HP9000 系列 700 <sup>™</sup> | HP-UX <sup>™</sup> (Rel. 10.10)   |        |
| 3K17 | SPARC 工作站 TM               | SunOS <sup>™</sup> (Rel. 4.1.4)   |        |
|      |                            | Solaris <sup>™</sup> (Rel. 2.5.1) |        |

 $\mu$ S $\times \times \times \times$ DF780547

| $\dashv$ | xxxx | 主机           | OS            | 存储介质          |
|----------|------|--------------|---------------|---------------|
|          | AB13 | PC-9800 系列   | Windows (日文版) | 3.5 英寸 2HD FD |
|          | BB13 | IBM PC/AT兼容机 | Windows (英文版) |               |

## A.3 控制软件

| PM+<br>项目管理器 | 这是一个控制软件,可使用户在 Windows 环境下有效地进行软件开发。用户程序开发中进行的任何操作,如启动编辑器、构造程序和启动调试器,都可以由项目管理器执行。 |
|--------------|-----------------------------------------------------------------------------------|
|              | <注意事项>                                                                            |
|              | 项目管理器包含在汇编编译器软件包 (RA78K0) 中。                                                      |
|              | 仅在 Windows 中使用。                                                                   |

# A.4 闪存写入工具

| FlashPro4<br>(产品型号: FL-PR4, PG-FP4)<br>闪存编程器 | 闪存编程器,专用于内置闪存的微控制器。                                                                                          |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| FlashPro4<br>(产品型号: PG-FPL3)<br>简单闪存编程器      | 简单闪存编程器专用于内置闪存的微控制器。                                                                                         |
| FA-80GC-8BT-A<br>FA-80GK-9EU-A<br>闪存写入适配器    | 闪存写入适配器用于连接 FlashPro4 用于连接 • FA-80GC-8BT-A: 80 引脚塑封 LQFP (GC-UBT 型) • FA-80GK-9EU-A: 80 引脚塑封 LQFP (GK-8EU 型) |

**备注:** FL-PR4、FA-80GC-8BT-A 和 FA-80GK-9EU-A 是 Naito Densei Machida Mfg. Co., Ltd 的产品。 TEL: +81-45-475-4191 Naito Densei Machida Mfg. Co., Ltd.

## A.5 调试工具 (硬件)

## A.5.1 当使用在线仿真器 QB-78K0KX2 时

| QB-78K0KX2 <sup>±1</sup><br>在线仿真器          | 在使用 78K0/Kx2 开发应用系统时,在线仿真器用于调试硬件和软件。它支持集成调试器(ID78K0-QB)。该仿真器应当与电源、仿真头及用于连接仿真器和主机的 USB 电缆结合使用。                  |  |
|--------------------------------------------|----------------------------------------------------------------------------------------------------------------|--|
| QB-144-CA-01<br>引脚检测适配器                    | 该适配器用于示波器等的波形检测                                                                                                |  |
| QB-80-EP-01T<br>仿真探头                       | 这是一种可以灵活使用的仿真探头,用于连接在线仿真器和目标系统。                                                                                |  |
| QB-80GC-EA-01T<br>QB-80GK-EA-01T<br>交换适配器  | 该适配器用于实现从在线仿真器到目标连接器的引脚转换 • QB-80GC-EA-01T: 80 引脚塑封 LQFP (GC-UBT 型) • QB-80GK-EA-01T: 80 引脚塑封 LQFP (GK-8EU 型)  |  |
| QB-80GC-YS-01T<br>QB-80GK-YS-01T<br>空间适配器  | 该适配器用于调整目标系统和在线仿真器之间的高度  • QB-80GC-YS-01T: 80 引脚塑封 LQFP (GC-UBT 型)  • QB-80GK-YS-01T: 80 引脚塑封 LQFP (GK-8EU 型)  |  |
| QB-80GC-YQ-01T<br>QB-80GK-YQ-01T<br>YQ 连接器 | 该连接器用于连接目标连接器和交换适配器。  • QB-80GC-YQ-01T: 80 引脚塑封 LQFP (GC-UBT 型)  • QB-80GK-YQ-01T: 80 引脚塑封 LQFP (GK-8EU 型)     |  |
| QB-80GC-HQ-01T<br>QB-80GK-HQ-01T<br>安装适配器  | 该适配器用于安装目标设备(通过插座安装到目标设备上) • QB-80GC-HQ-01T: 80 引脚塑封 LQFP (GC-UBT 型) • QB-80GK-HQ-01T: 80 引脚塑封 LQFP (GK-8EU 型) |  |
| QB-80GC-NQ-01T<br>QB-80GK-NQ-01T<br>目标连接器  | 该连接器用于将在线仿真器安装到目标系统上  • QB-80GC-NQ-01T: 80 引脚塑封 LQFP (GC-UBT 型)  • QB-80GK-NQ-01T: 80 引脚塑封 LQFP (GK-8EU 型)     |  |

注: 使用 QB-78K0KX2 时应提供电源、USB 接口电缆。作为控制软件,还提供集成调试器 ID78K0-QB 和简单闪存编程器 PG-FPL3。

备注: 封装内容随产品型号而变化,如下所示:

| 封装内容             | 在线仿真器      | 仿真头          | 交换适配器          | YQ 连接器         | 目标连接器          |
|------------------|------------|--------------|----------------|----------------|----------------|
| 产品型号             |            |              |                |                |                |
| QB-78K0KX2-ZZZ   | QB-78K0KX2 | 无            |                |                |                |
| QB-78K0KX2-T80GC |            | QB-80-EP-01T | QB-80GC-EA-01T | QB-80GC-YQ-01T | QB-80GC-NQ-01T |
| QB-78K0KX2-T80GK |            |              | QB-80GK-EA-01T | QB-80GK-YQ-01T | QB-80GK-NQ-01T |

#### ★ A.5.2 当使用片上调试仿真器 QB-78K0MINI 时

| QB-78K0MINI <sup>推</sup><br>片上调试仿真器 | 在使用 78K0/Kx2 开发应用系统时,片上调试仿真器用于调试硬件和软件。它支持集成调试器 (ID78K0-QB)。该仿真器使用一条连接电缆和一条用于连接主机的 USB 接口电缆。 |  |
|-------------------------------------|---------------------------------------------------------------------------------------------|--|
| 目标连接器规范说明                           | 10 引脚通用连接器(2.54 mm 脚距)                                                                      |  |

注: 使用 QB-78K0MINI 时提供 USB 接口电缆和一个连接电缆。作为控制软件,还提供集成调试器 ID78K0-QB。

# A.6 调试工具(软件)

| 用于 <b>78K0/KX2</b> 的 <b>SM+</b><br>系统模拟器 | 用于 78K0/KX2 的 SM+是基于 Windows 的软件。<br>在主机上模拟目标系统操作时,该仿真器用来执行 C 源程序或汇编程序级的调试操作。<br>使用 78K0/KX2 的 SM+可在不依赖硬件开发的基础上进行应用逻辑测试和性能测试,从而<br>提供了较高的开发效率和软件质量。<br>78K0/KX2 的 SM+应当结合设备文件(DF780547) (独立销售)使用。<br>产品型号: SM780547-B |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ID78K0-QB<br>集成调试器                       | 该调试器支持 78K/0 系列的在线仿真器。ID78K0-QB 是基于 Windows 的软件。它改善了 C 兼容的调试功能,并使用集成窗口功能(结合源程序、分开显示和跟踪结果的存储区显示)来显示源程序的跟踪结果。该调试器应当结合设备文件(独立销售)一起使用。产品型号: $\mu$ S××××ID78K0-QB                                                          |

备注:产品型号中的××××随主机和使用的 OS 不同而变化。

 $\mu \text{S} \times \times \times \text{SM780547-B} \\ \mu \text{S} \times \times \times \text{ID78K0-QB}$ 

| xxxx | 主机           | OS            | 存储介质   |
|------|--------------|---------------|--------|
| AB17 | PC-9800 系列   | Windows (日文版) | CD-ROM |
| BB17 | IBM PC/AT兼容机 | Windows (英文版) |        |

# 附录 B 目标系统设计的注解

本节显示了在使用 QB-78K0KX2 时,目标系统中禁止安装组件的区域和安装组件受严格限制的区域。



图 B-1. 80 引脚 GC 封装

□: 交换适配器区域: 可以安装最高达 17.45 mm 的组件<sup>±</sup>□: 仿真器探头区域: 可以安装最高达 24.45 mm 的组件<sup>±</sup>

注: 使用空间适配器可以调整高度(每个增加 2.4 mm)

图 B-2. 80 引脚 GK 封装



□: 交换适配器区域: 可以安装最高达 17.45 mm 的组件<sup>±</sup>□: 仿真器探头区域: 可以安装最高达 24.45 mm 的组件<sup>±</sup>

注: 使用空间适配器可以调整高度(每个增加 2.4 mm)

### 附录 C 寄存器索引

# C.1 寄存器索引 (按寄存器名称的字母顺序排列)

| [A]                          |          |
|------------------------------|----------|
| A/D 转换器模式寄存器 (ADM)           | 293      |
| A/D 端口配置寄存器 (ADPC)           | 120, 299 |
| 模拟输入通道选择寄存器 (ADS)            | 298      |
| 异步串行接口控制寄存器 6 (ASICL6)       | 346      |
| 异步串行接口操作模式寄存器 0 (ASIMO)      | 316      |
| 异步串行接口操作模式寄存器 6 (ASIM6)      | 340      |
| 异步串行接口接收错误状态寄存器 0 (ASISO)    | 318      |
| 异步串行接口接收错误状态寄存器 6 (ASIS6)    | 342      |
| 异步串行接口发送状态寄存器 6 (ASIF6)      | 343      |
| 自动数据传送地址计数寄存器 0 (ADTC0)      | 402      |
| 自动数据传送地址指针指定寄存器 0 (ADTP0)    | 400      |
| 自动数据传送间隔指定寄存器 0 (ADTI0)      | 401      |
| [B]                          |          |
| 波特率发生器控制寄存器 0 (BRGC0)        |          |
| 波特率发生器控制寄存器 6 (BRGC6)        | 345      |
| [C]                          |          |
| 捕捉/比较控制寄存器 00 (CRC00)        |          |
| 捕捉/比较控制寄存器 01 (CRC01)        |          |
| 时钟操作模式选择寄存器 (OSCCTL)         |          |
| 时钟输出选择寄存器 (CKS)              |          |
| 时钟选择寄存器 6 (CKSR6)            | 344      |
| [D]                          |          |
| 除数选择寄存器 0 (BRGCA0)           | 399      |
| (E)                          |          |
| 8 位 A/D 转换结果寄存器 (ADCRH)      |          |
| 8 位定时器比较寄存器 50 (CR50)        |          |
| 8 位定时器比较寄存器 51 (CR51)        |          |
| 8 位定时器计数器 50 (TM50)          |          |
| 8 位定时器计数器 51 (TM51)          |          |
| 8 位定时器 H 载波器控制寄存器 1 (TMCYC1) |          |
| 8 位定时器 H 比较寄存器 00 (CMP00)    |          |
| 8 位定时器 H 比较寄存器 01 (CMP01)    |          |
| 8 位定时器 H 比较寄存器 10 (CMP10)    |          |
| 8 位定时器 H 比较寄存器 11 (CMP11)    |          |
| 8 位定时器 H 模式寄存器 0 (TMHMD0)    |          |
| 8 位定时器 H 模式寄存器 1 (TMHMD1)    | 252      |
| 8 位定时器模式控制寄存器 50 (TMC50)     | 236      |
| 8 位定时器模式控制寄存器 51 (TMC51)     | 236      |

| 外部中断下降沿使能寄存器 (EGN)              | 520         |
|---------------------------------|-------------|
| 外部中断上升沿使能寄存器 (EGP)              | 520         |
| (I)                             |             |
| IIC 时钟选择寄存器 0 (IICCL0)          | 444         |
| IIC 控制寄存器 0 (IICC0)             | 435         |
| IIC 标志寄存器 0 (IICF0)             | 442         |
| IIC 功能扩展寄存器 0 (IICX0)           | 445         |
| IIC 移位寄存器 0 (IIC0)              | 432         |
| IIC 状态寄存器 0 (IICS0)             | 440         |
| 输入切换控制寄存器 (ISC)                 | 348         |
| 内部扩展 RAM 容量切换寄存器 (IXS)          | 582         |
| 内存容量切换寄存器 (IMS)                 | 581         |
| 内部振荡模式寄存器 (RCM)                 | 132         |
| 中断屏蔽标志寄存器 OH (MKOH)             | 518         |
| 中断屏蔽标志寄存器 OL (MKOL)             | 518         |
| 中断屏蔽标志寄存器 1H (MK1H)             | 518         |
| 中断屏蔽标志寄存器 1L (MK1L)             | 518         |
| 中断请求标志寄存器 OH (IFOH)             | 516         |
| 中断请求标志寄存器 OL (IFOL)             | 516         |
| 中断请求标志寄存器 1H (IF1H)             | 516         |
| 中断请求标志寄存器 1L (IF1L)             | 516         |
| IN1                             |             |
| [ <b>K</b> ]<br>按键返回模式寄存器 (KRM) | 530         |
| [L]                             |             |
| [上]<br>低电压检测等级选择寄存器 (LVIS)      | 563         |
| 低电压检测寄存器 (LVIM)                 |             |
| 以电压位例可存储 (LV IIVI)              | 501         |
| [M]                             |             |
| 主时钟模式寄存器 (MCM)                  |             |
| 主 OSC 控制寄存器 (MOC)               | 133         |
| 存储器组选择寄存器 (BANK)                |             |
| 乘/除数寄存器 A0 (MDA0H, MDA0L)       |             |
| 乘/除数寄存器 B0 (MDB0)               |             |
| 乘法器/除法器控制寄存器 0 (DMUC0)          | 504         |
| [0]                             |             |
| 振荡稳定时间计数器状态寄存器 (OSTC)           | 135, 532    |
| 振荡稳定时间选择寄存器 (OSTS)              |             |
| rp)                             |             |
| [P]<br>端口模式寄存器 0 (PM0)          | 116 177 377 |
| 端口模式寄存器 1 (PM1)                 |             |
| 端口模式寄存器 2 (PM2)                 |             |
| 端口模式寄存器 3 (PM3)                 |             |
| 端口模式寄存器 4 (PM4)                 |             |
| 端口模式寄存器 5 (PM5)                 |             |
| BA : 150- 4:4 14 HH ← /         |             |

| 端口模式寄存器 6 (PM6)         | 116, 447      |
|-------------------------|---------------|
| 端口模式寄存器 7 (PM7)         | 116           |
| 端口模式寄存器 12 (PM12)       | 116, 563      |
| 端口模式寄存器 14 (PM14)       | 116, 289, 402 |
| 端口寄存器 0 (P0)            | 118           |
| 端口寄存器 1 (P1)            | 118           |
| 端口寄存器 2 (P2)            | 118           |
| 端口寄存器 3 (P3)            | 118           |
| 端口寄存器 4 (P4)            | 118           |
| 端口寄存器 5 (P5)            | 118           |
| 端口寄存器 6 (P6)            | 118           |
| 端口寄存器 7 (P7)            | 118           |
| 端口寄存器 12 (P12)          |               |
| 端口寄存器 13 (P13)          |               |
| 端口寄存器 14 (P14)          |               |
| 预分频器模式寄存器 00 (PRM00)    |               |
| 预分频器模式寄存器 01 (PRM01)    | 175           |
| 优先级指定标志寄存器 0H (PR0H)    |               |
| 优先级指定标志寄存器 OL (PROL)    |               |
| 优先级指定标志寄存器 1H (PR1H)    |               |
| 优先级指定标志寄存器 1L (PR1L)    |               |
| 处理器时钟控制寄存器 (PCC)        |               |
| 上拉电阻选择寄存器 0 (PU0)       |               |
| 上拉电阻选择寄存器 1 (PU1)       |               |
| 上拉电阻选择寄存器 3 (PU3)       |               |
| 上拉电阻选择寄存器 4 (PU4)       |               |
| 上拉电阻选择寄存器 5 (PU5)       |               |
| 上拉电阻选择寄存器 6 (PU6)       |               |
| 上拉电阻选择寄存器 7 (PU7)       |               |
| 上拉电阻选择寄存器 12 (PU12)     |               |
| 上拉电阻选择寄存器 14 (PU14)     | 119           |
| [R]                     |               |
| 接收缓冲寄存器 0 (RXB0)        |               |
| 接收缓冲寄存器 6 (RXB6)        |               |
| 接收移位寄存器 0 (RXS0)        |               |
| 接收移位寄存器 6 (RXS6)        |               |
| 余数寄存器 0 (SDR0)          |               |
| 复位控制标志寄存器 (RESF)        | 552           |
| [8]                     |               |
| 串行时钟选择寄存器 10 (CSIC10)   |               |
| 串行时钟选择寄存器 11 (CSIC11)   |               |
| 串行 I/O 移位寄存器 0 (SIOA0)  |               |
| 串行 I/O 移位寄存器 10 (SIO10) |               |
| 串行 I/O 移位寄存器 11 (SIO11) | 372           |

### 附录 C 寄存器索引

| 串行操作模式寄存器 10 (CSIM10)       | 373 |
|-----------------------------|-----|
| 串行操作模式寄存器 11 (CSIM11)       | 373 |
| 串行操作模式选择寄存器 0 (CSIMA0)      | 395 |
| 串行状态寄存器 0 (CSIS0)           | 396 |
| 串行触发器寄存器 0 (CSIT0)          | 398 |
| 16 位定时器捕捉/比较寄存器 000 (CR000) | 164 |
| 16 位定时器捕捉/比较寄存器 001 (CR001) | 164 |
| 16 位定时器捕捉/比较寄存器 010 (CR010) | 164 |
| 16 位定时器捕捉/比较寄存器 011 (CR011) | 164 |
| 16 位定时器计数器 00 (TM00)        | 163 |
| 16 位定时器计数器 01 (TM00)        | 163 |
| 16 位定时器模式控制寄存器 00 (TMC00)   | 167 |
| 16 位定时器模式控制寄存器 01 (TMC01)   | 167 |
| 16 位定时器输出控制寄存器 00 (TOC00)   | 172 |
| 16 位定时器输出控制寄存器 01 (TOC01)   | 172 |
| 从设备地址寄存器 0 (SVA0)           | 432 |
| [T]                         |     |
| 定时器时钟选择寄存器 50 (TCL50)       | 234 |
| 定时器时钟选择寄存器 51 (TCL51)       | 234 |
| 10 位 A/D 转换结果寄存器 (ADCR)     | 296 |
| 发送缓冲寄存器 10 (SOTB10)         | 372 |
| 发送缓冲寄存器 11 (SOTB11)         | 372 |
| 发送缓冲寄存器 6 (TXB6)            | 339 |
| 发送移位寄存器 0 (TXS0)            | 315 |
| 发送移位寄存器 6 (TXS6)            | 339 |
| [w]                         |     |
| 钟表定时器操作模式寄存器 (WTM)          | 275 |
| 看门狗完时哭庙能客衣哭 (M/DTF)         | 281 |

## C.2 寄存器索引 (按寄存器符号的字母顺序排列)

| [A]     |                     |          |
|---------|---------------------|----------|
| ADCR:   | 10 位 A/D 转换结果寄存器    | 296      |
| ADCRH:  | 8 位 A/D 转换结果寄存器     | 297      |
| ADM:    | A/D 转换器模式寄存器        | 293      |
| ADPC:   | A/D 端口配置寄存器         | 120, 299 |
| ADS:    | 模拟输入通道选择寄存器         | 298      |
| ADTC0:  | 自动数据传送地址计数寄存器 0     | 402      |
| ADTI0:  | 自动数据传送间隔指定寄存器 0     | 401      |
| ADTP0:  | 自动数据传送地址指针指定寄存器 0   | 400      |
| ASICL6: | 异步串行接口控制寄存器 6       | 346      |
| ASIF6:  | 异步串行接口发送状态寄存器 6     | 343      |
| ASIM0:  | 异步串行接口操作模式寄存器 0     | 316      |
| ASIM6:  | 异步串行接口操作模式寄存器 6     | 340      |
| ASIS0:  | 异步串行接口接收错误状态寄存器 0   | 318      |
| ASIS6:  | 异步串行接口接收错误状态寄存器 6   | 342      |
| [B]     |                     |          |
| BANK:   | 存储器组选择寄存器           | 79       |
| BRGC0:  | 波特率发生器控制寄存器 0       |          |
| BRGC6:  | 波特率发生器控制寄存器 6       |          |
| BRGCA0: | 除数选择寄存器 0           |          |
|         |                     |          |
| [C]     |                     |          |
| CKS:    | 时钟输出选择寄存器           |          |
| CKSR6:  | 时钟选择寄存器 6           |          |
| CMP00:  | 8 位定时器 H 比较寄存器 00   |          |
| CMP01:  | 8 位定时器 H 比较寄存器 01   |          |
| CMP10:  | 8 位定时器 H 比较寄存器 10   |          |
| CMP11:  | 8 位定时器 H 比较寄存器 11   |          |
| CR000:  | 16 位定时器捕捉/比较寄存器 000 |          |
| CR001:  | 16 位定时器捕捉/比较寄存器 000 |          |
| CR010:  | 16 位定时器捕捉/比较寄存器 010 |          |
| CR011:  | 16 位定时器捕捉/比较寄存器 011 |          |
| CR50:   | 8位定时器比较寄存器 50       |          |
| CR51:   | 8位定时器比较寄存器 51       | 233      |
| CRC00:  | 捕捉/比较控制寄存器 00       | 170      |
| CRC01:  | 捕捉/比较控制寄存器 01       | 170      |
| CSIC10: | 串行时钟选择寄存器 10        | 375      |
| CSIC11: | 串行时钟选择寄存器 11        | 375      |
| CSIM10: | 串行操作模式寄存器 10        | 373      |
| CSIM11: | 串行操作模式寄存器 11        | 373      |
| CSIMA0: | 串行操作模式选择寄存器 0       | 395      |
| CSIS0:  | 串行状态寄存器 0           | 396      |
| CSIT0:  | 串行触发器寄存器 <b>0</b>   | 398      |

| DMUC0:  | 乘法器/除法器控制寄存器 0   | 504      |  |
|---------|------------------|----------|--|
| [E]     |                  |          |  |
| EGN:    | 外部中断下降沿使能寄存器     | 520      |  |
| EGP:    | 外部中断上升沿使能寄存器     | 520      |  |
| [1]     |                  |          |  |
| IF0H:   | 中断请求标志寄存器 0H     | 516      |  |
| IF0L:   | 中断请求标志寄存器 OL     | 516      |  |
| IF1H:   | 中断请求标志寄存器 1H     | 516      |  |
| IF1L:   | 中断请求标志寄存器 1L     | 516      |  |
| IIC0:   | IIC 移位寄存器 0      | 432      |  |
| IICC0:  | IIC 控制寄存器 0      | 435      |  |
| IICCL0: | IIC 时钟选择寄存器 0    | 444      |  |
| IICF0:  | IIC 标志寄存器 0      | 442      |  |
| IICS0:  | IIC 状态寄存器 0      | 440      |  |
| IICX0:  | IIC 功能扩展寄存器 0    | 445      |  |
| IMS:    | 内存容量切换寄存器        | 581      |  |
| ISC:    | 输入切换控制寄存器        | 348      |  |
| IXS:    | 内部扩展 RAM 容量切换寄存器 | 582      |  |
| [K]     |                  |          |  |
| KRM:    | 按键返回模式寄存器        | 530      |  |
| [L]     |                  |          |  |
| LVIM:   | 低电压检测寄存器         | 561      |  |
| LVIS:   | 低电压检测等级选择寄存器     | 562      |  |
| [M]     |                  |          |  |
| MCM:    | 主时钟模式寄存器         | 134      |  |
| MDA0H:  | 乘/除数寄存器 A0       | 502      |  |
| MDA0L:  | 乘/除数寄存器 A0       | 502      |  |
| MDB0:   | 乘/除数 寄存器 B0      | 503      |  |
| MK0H:   | 中断屏蔽标志寄存器 0H     | 518      |  |
| MK0L:   | 中断屏蔽标志寄存器 OL     | 518      |  |
| MK1H:   | 中断屏蔽标志寄存器 1H     | 518      |  |
| MK1L:   | 中断屏蔽标志寄存器 1L     | 518      |  |
| MOC:    | 主 OSC 控制寄存器      | 133      |  |
| [0]     |                  |          |  |
| OSCCTL: | 时钟操作模式选择寄存器      | 128      |  |
| OSTC:   | 振荡稳定时间计数器状态寄存器   | 135, 532 |  |
| OSTS:   | S: 振荡稳定时间选择寄存器   |          |  |
| [P]     |                  |          |  |
| P0:     | 端口寄存器 0          |          |  |
| P1:     | 端口寄存器 1          |          |  |
| P2:     | 端口寄存器 2          | 118      |  |

| P3:    | 端口寄存器 3         | 118                          |
|--------|-----------------|------------------------------|
| P4:    | 端口寄存器 4         | 118                          |
| P5:    | 端口寄存器 5         | 118                          |
| P6:    | 端口寄存器 6         | 118                          |
| P7:    | 端口寄存器 7         | 118                          |
| P12:   | 端口寄存器 12        | 118                          |
| P13:   | 端口寄存器 13        | 118                          |
| P14:   | 端口寄存器 14        | 118                          |
| PCC:   | 处理器时钟控制寄存器      | 130                          |
| PM0:   | 端口模式寄存器 0       | 116, 177, 377                |
| PM1:   | 端口模式寄存器 1       | 116, 238, 256, 320, 348, 377 |
| PM2:   | 端口模式寄存器 2       | 116, 300                     |
| PM3:   | 端口模式寄存器 3       | 116, 238                     |
| PM4:   | 端口模式寄存器 4       | 116                          |
| PM5:   | 端口模式寄存器 5       | 116                          |
| PM6:   | 端口模式寄存器 6       | 116, 447                     |
| PM7:   | 端口模式寄存器 7       | 116                          |
| PM12:  | 端口模式寄存器 12      | 116, 563                     |
| PM14:  | 端口模式寄存器 14      | 116, 289, 402                |
| PR0H:  | 优先级指定标志寄存器 0H   | 519                          |
| PR0L:  | 优先级指定标志寄存器 OL   | 519                          |
| PR1H:  | 优先级指定标志寄存器 1H   | 519                          |
| PR1L:  | 优先级指定标志寄存器 1L   | 519                          |
| PRM00: | 预分频器模式寄存器 00    | 175                          |
| PRM01: | 预分频器模式寄存器 01    | 175                          |
| PU0:   | 上拉电阻选择寄存器 0     | 119                          |
| PU1:   | 上拉电阻选择寄存器 1     | 119                          |
| PU3:   | 上拉电阻选择寄存器 3     | 119                          |
| PU4:   | 上拉电阻选择寄存器 4     | 119                          |
| PU5:   | 上拉电阻选择寄存器 5     | 119                          |
| PU6:   | 上拉电阻选择寄存器 6     | 119                          |
| PU7:   | 上拉电阻选择寄存器 7     | 119                          |
| PU12:  | 上拉电阻选择寄存器 12    | 119                          |
| PU14:  | 上拉电阻选择寄存器 14    | 119                          |
| [R]    |                 |                              |
| RCM:   | 内部振荡模式寄存器       | 132                          |
| RESF:  | 复位控制标志寄存器       | 552                          |
| RXB0:  | 接收缓冲寄存器 0       | 315                          |
| RXB6:  | 接收缓冲寄存器 6       | 339                          |
| RXS0:  | 接收移位寄存器 0       | 315                          |
| RXS6:  | 接收移位寄存器 6       | 339                          |
| [S]    |                 |                              |
| SDR0:  | 余数寄存器 0         | 502                          |
| SIO10: | 串行 I/O 移位寄存器 10 | 372                          |

### 附录 C 寄存器索引

| SIO11:  | 串行 I/O 移位寄存器 11     | 372 |
|---------|---------------------|-----|
| SIOA0:  | 串行 I/O 移位寄存器 0      | 394 |
| SOTB10: | 发送缓冲寄存器 10          | 372 |
| SOTB11: | 发送缓冲寄存器 11          | 372 |
| SVA0:   | 从设备地址寄存器 0          | 432 |
| [T]     |                     |     |
| TCL50:  | 定时器时钟选择寄存器 50       | 234 |
| TCL51:  | 定时器时钟选择寄存器 51       | 234 |
| TM00:   | 16 位定时器计数器 00       | 163 |
| TM01:   | 16 位定时器计数器 01       | 163 |
| TM50:   | 8 位定时器计数器 50        | 233 |
| TM51:   | 8 位定时器计数器 51        | 233 |
| TMC00:  | 16 位定时器模式控制寄存器 00   | 167 |
| TMC01:  | 16 位定时器模式控制寄存器 01   | 167 |
| TMC50:  | 8 位定时器模式控制寄存器 50    | 236 |
| TMC51:  | 8 位定时器模式控制寄存器 51    | 236 |
| TMCYC1: | 8 位定时器 H 载波器控制寄存器 1 | 256 |
| TMHMD0: | 8 位定时器 H 模式 寄存器 0   | 252 |
| TMHMD1: | 8 位定时器 H 模式 寄存器 1   | 252 |
| TOC00:  | 16 位定时器输出控制寄存器 00   | 172 |
| TOC01:  | 16 位定时器输出控制寄存器 01   | 172 |
| TXB6:   | 发送缓冲寄存器 6           | 339 |
| TXS0:   | 发送移位寄存器 0           | 315 |
| TXS6:   | 发送移位寄存器 6           | 339 |
| [W]     |                     |     |
| WDTE:   | 看门狗定时器使能寄存器         | 281 |
| WTM:    | 钟表定时器操作模式寄存器        | 275 |

### D.1 本版中主要修订之处

(1/7)

| 页码               | (1/7) 描述                                                                                    |
|------------------|---------------------------------------------------------------------------------------------|
| 第一章 概述           | 加处                                                                                          |
| pp. 17, 18       | 添加具有片上调试功能的产品的 <b>注</b> ,修改 <b>1.1 特征</b> 中的工作环境温度。                                         |
| p. 18            | 在 1.2 应用中添加支持汽车设备的专用等级产品。                                                                   |
| p. 19            | 修改 <b>1.3 定购信息</b>                                                                          |
| p. 19            | 在 1.4 引脚配置(俯视图)中添加注并修改注意事项                                                                  |
| pp. 23, 24       | 修改 <b>1.5 78K0/Kx2 系列介绍</b> 的功能列表中的以下几项。                                                    |
| рр. 23, 24       | • 内部低速振荡时钟的供电电压                                                                             |
|                  | ● POC 的检测电压                                                                                 |
|                  | ◆工作环境温度                                                                                     |
| p. 25            | 在 <b>1.6 框图</b> 中添加具有 "片上调试"的引脚                                                             |
| pp. 26, 27       | 修改 <b>1.7 功能概述</b> 中的以下几项<br>  ● 高速系统时钟的振荡频率范围                                              |
|                  | • 内部低速振荡时钟的供电电压范围                                                                           |
|                  | ●工作环境温度                                                                                     |
| p. 27            | 修改 <b>1.7 功能概述</b> 中的定时器介绍                                                                  |
| 第二章 引脚功能         |                                                                                             |
| p. 28            | 修改表 2-1 引脚 I/O 缓冲式供电电源                                                                      |
| pp. 28 $\sim$ 31 | 在 <b>2.1 引脚功能列表</b> 中添加 <b>注</b>                                                            |
| p. 38            | 修改 2.2.16 Vdd 和 EVdd 以及 2.2.17 Vss 和 EVss 中的描述                                              |
| p. 38            | 在 2.2.15 中添加连线框图和 <b>注意事项</b>                                                               |
| p. 40            | 修改表 <b>2-2 引脚 I/O 电路类型</b> 中对未使用引脚 P121/X1、P122/X2/EXCLK、P123/XT1 和 P124/XT2/EXCLKS的建议连接方式。 |
| 第三章 CPU 结构       |                                                                                             |
| p. 43            | 在 <b>3.1 存储空间</b> 中添加 <b>注意事项 2</b>                                                         |
| p. 43            | 修改表 3-1 设置内存容量切换寄存器(IMS)和内部扩展 RAM 切换寄存器(IXS)的值                                              |
| pp. 44 $\sim$ 48 | 修改图 3-1 存储空间映射图( $\mu$ PD78F0544) $\sim$ 图 3-5 存储空间映射图( $\mu$ PD78F0547D)                   |
| p. 50            | 修改 3.1.1 的(3) 选项字节区域和(5) 片上调试安全 ID 设置区域(仅用于 <sub>H</sub> PD78F0547D)中的描述                    |
| p. 50            | 修改 3.1.2 存储器组(仅用于µPD78F0546, 78F0547 和 78F0547D)中的描述                                        |
| pp. 54, 55       | 添加图 3-8 数据存储空间与寻址方式的对应关系(#PD78F0546)和图 3-9 数据存储空间与寻址方式的对应关系 (#PD78F0547, 78F0547D)的注        |
| p. 66            | 添加 <b>3.3 指令地址寻址</b> 中的描述                                                                   |
| p. 67            | 添加 3.3.2 立即寻址中的描述                                                                           |
| p. 68            | 添加 <b>3.3.3 表间接寻址</b> 中的描述                                                                  |
| p. 71            | 添加 3.4.3 直接寻址中的描述                                                                           |
| p. 72            | 修改 3.4.4 短直接寻址中的[描述举例]                                                                      |
| p. 74            | 添加 3.4.6 寄存器间接寻址中的描述                                                                        |
| p. 75            | 添加 3.4.7 基址寻址中的描述                                                                           |
| p. 76            | 添加 3.4.8 基址变址寻址中的描述                                                                         |

657

(2/7)

|            |                | ,                                                                       | 2/7 |
|------------|----------------|-------------------------------------------------------------------------|-----|
| 页征         | 1              | 描述                                                                      |     |
| 第四章 存      | <b>存储器组选</b> 技 | <b>承功能 (仅用于μPD78F0546, 78F0547 和 78F0547D)</b>                          |     |
| p. 78      |                | 添加这一章                                                                   |     |
| 第五章 端      | <b>端口功能</b>    |                                                                         |     |
| p. 88      |                | 修改表 5-1 引脚 I/O 缓冲电源                                                     |     |
| p. 91      |                | 添加 <b>5.2.1 端口 0</b> 的 <b>注意事项</b>                                      |     |
| p. 95      |                | 添加 <b>5.2.2 端口 1</b> 的 <b>注意事项</b>                                      |     |
| p. 100     |                | 添加 5.2.3 端口 2 的描述,添加表 5-4 P20/ANIO ~ P27/ANI7 引脚的功能设置                   |     |
| p. 107     |                | 添加图 5-19 P64 ~ P67 的框图                                                  |     |
| p. 109     |                | 在 <b>5.2.9 端口 12</b> 中添加 <b>备注</b> ,并修改 <b>注意事项</b>                     |     |
| p. 109     |                | 修改图 5-21 P120 的框图                                                       |     |
| p. 110     |                | 修改图 5-22 P121 ~ P124 的框图                                                |     |
| p. 111     |                | 在 <b>5.2.10 端口 13</b> 的 <b>备注</b> 中添加了一个图                               |     |
| p. 120     |                | 在 5.3 控制端口功能的寄存器中添加(4) A/D 端口配置寄存器 (ADPC)                               |     |
| pp. 123, 1 | 124            | 在表 5-5 使用复用功能时,端口模式寄存器和输出锁存器的设置(2/2)中添加备注 2 和注 1、2                      |     |
| 第六章 时      | 付钟发生器          |                                                                         |     |
| p. 125     |                | 修改 <b>6.1 (1) 主系统时钟</b> 中 X1 振荡器和外部主系统时钟 的振荡频率范围                        |     |
| p. 126     |                | 在 <b>6.1 (3) 内部低速振荡时钟</b> 中添加描述                                         |     |
| p. 127     |                | 修改图 6-1 时钟发生器的框图                                                        |     |
| p. 130     |                | 修改图 6-3 处理器时钟控制寄存器(PCC)的格式                                              |     |
| p. 131     |                | 添加 6.3 (3) 子系统时钟引脚操作模式的设置                                               |     |
| p. 136     |                | 修改 <b>6.3 (8) 振荡稳定时间选择寄存器(OSTS)</b> 中的描述                                |     |
| p. 137     |                | 修改 <b>6.4.1 X1 振荡器</b> 的振荡频率范围                                          |     |
| p. 140     |                | 修改 <b>6.4.3 不使用子系统时钟</b> 中的描述                                           |     |
| p. 142     |                | 添加图 6-12 上电时的时钟发生器操作 (设置 1.59 V POC 模式 (选项字节: POCMODE = 0))             |     |
| p. 143     |                | 添加图 6-13 上电时的时钟发生器操作 (设置 2.7 V/1.59 V POC 模式(选项字节: POCMODE = 1))        |     |
| p. 144     |                | 修改 6.6.1 控制高速系统时钟                                                       |     |
| p. 147     |                | 修改 6.6.2 控制内部高速振荡时钟示例                                                   |     |
| p. 149     |                | 修改 6.6.3 控制子系统时钟示例                                                      |     |
| p. 151     |                | 修改 <b>表 6-4 CPU 和外部硬件采用的时钟及寄存器设置</b> 中的描述                               |     |
| p. 152     |                | 在图 6-14 CPU 时钟状态转换图(设置 1.59 V POC 模式(选项字节: POCMODE = 0))中添加备注           |     |
| pp. 153 ~  | ~ 156          | 在表 6-5 CPU 时钟切换与 SFR 寄存器设置示例中修改以下几项                                     |     |
|            |                | (3) 复位释放后(A)CPU 使用子系统时钟(D)                                              |     |
|            |                | (4) CPU 时钟从内部高速振荡时钟(B)切换到高速系统时钟(C)<br>(5) CPU 时钟从内部高速振荡时钟(B)切换到子系统时钟(D) |     |
|            |                | (3) CPU 时钟从内部局迷振荡的钟(B)切换到于系统时钟(D) (7) CPU 时钟从高速系统时钟(C)切换到子系统时钟(D)       |     |
|            |                | (9) CPU 时钟从子系统时钟(D)切换到高速系统时钟(C)                                         |     |
| p. 157     |                | 修改 <b>表 6-6 切换 CPU 时钟</b>                                               |     |

|              | (3/7)                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------|
| 页码           | 描述                                                                                              |
| p. 158       | 添加 6.6.8 CPU 时钟和主系统时钟切换所需的时间                                                                    |
| p. 159       | 添加 6.6.9 时钟振荡停止前的状况                                                                             |
| p. 160       | 添加 6.6.10 外部硬件与源时钟                                                                              |
| 第七章 16 位定时器  | A/事件计数器 00 和 01                                                                                 |
| p. 161       | 本章的修订                                                                                           |
| 第八章 8位定时器/   | 事件计数器 50 和 51                                                                                   |
| p. 233       | 修改 8.2 (2) 8 位定时器比较寄存器 5n (CR5n)中的描述                                                            |
| 第九章 8位定时器    | H0 和 H1                                                                                         |
| p. 250       | 修改图 9-2 8 位定时器 H1 的框图                                                                           |
| p. 251       | 修改 9.2 (1) 8 位定时器 H 比较寄存器 0n (CMP0n)和(2) 8 位定时器 H 比较寄存器 1n (CMP1n)中的描述                          |
| p. 255       | 修改图 9-6 8 位定时器 H 模式寄存器 1 (TMHMD1)的格式                                                            |
| p. 265       | 修改图 9-12 (e) 修改 CMP1n (CMP1n = 02H → 03H, CMP0n = A5H)时的操作时序                                    |
| p. 266       | 修改 9.4.3 载波发生器的操作(仅用于 8 位定时器 H1)中的描述                                                            |
| p. 267       | 在 <b>图 9-13 传送时序</b> 中添加<3>                                                                     |
| p. 268       | 在 9.4.3 设置 中添加<8>                                                                               |
| pp. 270, 271 | 修改图 9-15(a) 当 CMP01 = N, CMP11 = N 时的操作和(b) 当 CMP01 = N, CMP11 = M 时的操作                         |
| p. 272       | 修改 <b>图 9-15 (c) CMP11 改变时的操作时序</b> 中的描述                                                        |
| 第十一章 看门狗定    | 时器                                                                                              |
| p. 279       | 修改 <b>11.1 看门狗定时器的功能</b> 中的描述                                                                   |
| pp. 282, 283 | 在 11.4.1 控制看门狗定时器的操作中添加描述和注意事项 4                                                                |
| 第十二章 时钟输出    | /蜂鸣器输出控制器                                                                                       |
| p. 288       | 在图 12-2 时钟输出选择寄存器(CKS)的格式中添加注 1 和注意事项 1 和 2                                                     |
| 第十三章 A/D 转换  | <del>器</del>                                                                                    |
| pp. 291, 292 | 在 <b>13.2 A/D 转换器的配置</b> 中修改以下几项                                                                |
|              | (2) 采样与保持电路                                                                                     |
|              | (3) 串联电阻串<br>(5) 逐次逼近寄存器(SAR)                                                                   |
|              | (9) AVREF引脚                                                                                     |
| p. 295       | 表 13-2 A/D 转换时间选择中添加注意事项 1 和 4                                                                  |
| p. 298       | 修改图 13-8 模拟输入通道选择寄存器(ADS)的格式中的注意事项 2 和 3                                                        |
| p. 299       | 修改 <b>13.3 (5) A/D 端口配置寄存器(ADPC)</b> 中的描述                                                       |
| p. 299       | 修改图 13-9 A/D 端口配置寄存器(ADPC)的格式中的注意事项 1 和 2                                                       |
| p. 300       | 修改表 13-3 ANIO/P20 ~ ANI7/P27 引脚功能设置                                                             |
| p. 301       | 修改 13.4.1 A/D 转换器的基本操作                                                                          |
| p. 302       | 修改 <b>图 13-11 A/D 转换器的基本操作</b> 中的描述                                                             |
| p. 303       | 修改 <b>13.4.2 输入电压和转换结果</b> 中的表达式                                                                |
| pp. 304, 305 | 修改 <b>13.4.3 A/D 转换器操作模式</b> 中的描述                                                               |
| pp. 308, 309 | 修改 13.6 A/D 转换器的注意事项中以下几项描述 (1) STOP 模式中的操作电流 (4) 解决噪音问题的方法 (6) ANIO ~ ANI7 引脚的输入阻抗 (11) 内部等效电路 |

(4/7)

| 页码           | (4/7)<br>描述                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------|
| 第十四章 串行接口    |                                                                                               |
| p. 312       | 在 <b>14.1 (2) 异步串行接口 (UART)模式</b> 中添加最大传送速率和 <b>注意事项 4</b>                                    |
| p. 315       | 在 14.2 (3) 发送移位寄存器 0 (TXS0)中添加注意事项 1                                                          |
| p. 317       | 在图 14-2 异步串行接口操作模式寄存器 0 (ASIMO)的格式中添加注意事项 5                                                   |
| p. 318       | 修改 14.3 (2) 异步串行接口接收错误状态寄存器 0 (ASISO)中的描述                                                     |
| p. 326       | 修改图 14-9 接收完成中断请求时序中的注意事项 1                                                                   |
| p. 329       | 添加表 14-4 TPS01 和 TPS00 的设置值                                                                   |
| 第十五章 串行接口    | UART6                                                                                         |
| p. 333       | 在 <b>15.1 (2) 异步串行接口 (UART)模式</b> 中添加最大传送速率和 <b>注意事项 4</b> 和 <b>5</b>                         |
| p. 334       | 修改图 15-1 LIN 发送操作                                                                             |
| p. 335       | 修改 <b>图 15-2 LIN 接收操作</b>                                                                     |
| p. 339       | 在 15.2 (3) 发送缓冲寄存器 6 (TXB6)中添加注意事项 3                                                          |
| p. 341       | 在图 15-5 异步串行接口操作模式寄存器 6 (ASIM6)的格式中添加注意事项 4 和 5                                               |
| p. 342       | 修改 <b>15.3 (2) 异步串行接口接收错误状态寄存器 6 (ASIS6)</b> 中的描述                                             |
| p. 347       | 在图 15-10 异步串行接口控制寄存器 6 (ASICL6)的格式中添加注意事项 6                                                   |
| p. 348       | 修改 15.3 (7) 输入切换控制寄存器 (ISC)中的描述                                                               |
| p. 359       | 修改 15.4.2 (2) (e) 正常接收中的注意事项 1                                                                |
| 第十六章 串行接口    | CSI10, CSI11                                                                                  |
| p. 371       | 修改图 16-1 串行接口 CSI10 的框图                                                                       |
| p. 372       | 修改图 16-2 串行接口 CSI11 的框图                                                                       |
| p. 372       | 修改 16.2 (1) 发送缓冲寄存器 1n (SOTB1n)中的注意事项 2                                                       |
| p. 372       | 修改 16.2 (2) 串行 I/O 移位寄存器 1n (SIO1n)中的注意事项 2                                                   |
| p. 373       | 修改图 16-3 串行操作模式寄存器 10 (CSIM10)的格式中的注 2                                                        |
| p. 374       | 修改图 16-4 串行操作模式寄存器 11 (CSIM11)的格式中的注 2                                                        |
| p. 375       | 修改图 16-5 串行时钟选择寄存器 10 (CSIC10)的格式中的注意事项 2                                                     |
| p. 376       | 修改图 16-6 串行时钟选择寄存器 11 (CSIC11)的格式中的注意事项 2                                                     |
| p. 378       | 修改 <b>16.4.1 (1) 使用的寄存器</b> 中 CSIM10 和 CSIM11 的 <b>注 1</b>                                    |
| pp. 386, 387 | 在图 16-11 第一位的输出操作中添加(b) 类型 3: CKP1n = 1, DAP1n = 0 和 (d) 类型 4: CKP1n = 1, DAP1n               |
| 000 000      | = 1                                                                                           |
| pp. 388, 389 | 在图 16-12 SO1n 引脚的输出值 (最后一位)中添加(b) 类型 3: CKP1n = 1, DAP1n = 0 和 (d) 类型 4: CKP1n = 1, DAP1n = 1 |
| 第十七章 串行接口    |                                                                                               |
| p. 411       | 修改 17.4.3 (2) 自动发送/接收数据的设置                                                                    |
| p. 414       | 修改图 17-14 自动发送/接收模式流程图                                                                        |
| pp. 415, 416 | 修改 <b>17.4.3 (3) (a) 自动发送/接收模式 ((i) 启动自动发送/接收, (ii) 发送/接收完成)</b> 中关于内部缓冲 RAM 的描述              |

(5/7)

|                    | (5/7                                                                   |
|--------------------|------------------------------------------------------------------------|
| 页码                 | 描述                                                                     |
| p. 419             | 修改图 17-18 自动发送模式流程图                                                    |
| p. 421             | 修改图 17-20 重复发送模式流程图                                                    |
| pp. 424, 425       | 修改 <b>17.4.3 (4) (a) 忙控制选项</b> 中的描述                                    |
| p. 427             | 修改图 17-27 根据忙信号进行移位检测的操作时序(当 BUSYLV0 = 1)                              |
| p. 428             | 修改 <b>17.4.3 (5) 自动发送/接收间隔时间</b> 中的描述                                  |
| p. 428             | 修改图 17-28 自动发送/接收间隔时间举例(当 ADTI0 = 00H, STBE0 = 1, BUSYE0 = 0 (两个时钟))   |
| 第十八章 串行接口          | IICO                                                                   |
| p. 430             | 修改 <b>图 18-1 串行接口 IIC0 的框图</b>                                         |
| p. 432             | 在 18.2 (1) IIC 移位寄存器 0 (IIC0)添加注意事项 2,并添加(2) 从地址寄存器 0 (SVA0) 的描述       |
| p. 433             | 添加 18.2 (13) 停止条件发生器                                                   |
| p. 436             | 在图 18-5 IIC 控制寄存器 0 (IICC0)的格式 (1/4)中添加对 IICE0 的描述,并添加 <b>注意事项</b>     |
| p. 437             | 添加对图 18-5 IIC 控制寄存器 0 (IICC0)的格式 (2/4)的注 2                             |
| p. 438             | 在图 18-5 IIC 控制寄存器 0 (IICC0)的格式 (3/4)中添加对 STT0 的描述                      |
| p. 443             | 在图 18-7 IIC 标志寄存器 0 (IICF0)的格式中添加对 STCF 和 IICBSY 的清零条件                 |
| p. 444             | 修改 18.3 (4) IIC 时钟选择寄存器 0 (IICCL0)中的描述                                 |
| pp. 445, 446       | 修改 <b>18.3 (6) I<sup>2</sup>C 传送时钟设置方法</b> 中的描述                        |
| p. 446             | 修改表 18-2 选择时钟的设置                                                       |
| p. 451             | 在 <b>18.5.4 应答信号 (ACK)中</b> 添加不能返回 ACK 的原因                             |
| p. 455             | 添加 <b>18.5.7 取消等待</b>                                                  |
| pp. 460, 461       | 修改表 18-6 等待周期和图 18-20 通信保留时序                                           |
| p. 463             | 修改 <b>表 18-7 等待周期</b>                                                  |
| pp. 463, 464       | 在 <b>18.5.15 其它注意事项</b> 中添加( <b>4</b> ) $\sim$ ( <b>6</b> )            |
| pp. 465, 466       | 修改 18.5.16 (1) 主设备操作(单主设备系统) 和 (2) 主设备操作(多主设备系统)                       |
| pp. 470, 471       | 修改图 18-25 从设备操作流程图(1) 和图 18-26 从设备操作流程图(2)                             |
| p. 473             | 在 18.5.17 (1) 主设备操作的(a) (i) 当 WTIM0 = 0 中添加注,并修改(ii) 当 WTIM0 = 1       |
| p. 474             | 在 18.5.17 (1) 主设备操作的(b) (i) 当 WTIM0 = 0 中添加注 1~3                       |
| p. 475             | 在 18.5.17 (1) 主设备操作的(c) (i) 当 WTIM0 = 0 中添加注                           |
| pp. 479, 483, 489, | 在 18.5.17 中修改 IICSO 寄存器的以下几项的值                                         |
| 492                | (2) (d) (i) 当 WTIM0 = 0 (重启后,地址不匹配 (= 非扩展码))                           |
|                    | (2) (d) (ii) 当 WTIM0 = 1 (重启后,地址不匹配 (= 非扩展码))                          |
|                    | (3) (d) (i) 当 WTIM0 = 0 (重启后,地址不匹配 (= 非扩展码))                           |
|                    | (3) (d) (ii) 当 WTIM0 = 1 (重启后,地址不匹配 (= 非扩展码))                          |
|                    | (6) (d) (ii) 扩展码                                                       |
|                    | (6) (e) 数据传送期间由于停止导致仲裁失败时<br>  (6) (h) (ii) 当 WTIM0 = 1                |
|                    |                                                                        |
| pp. 484, 486       | 在 18.5.17 (5) 仲裁失败操作 (仲裁失败后作为从设备操作) 和 (6) 发生仲裁失败时的操作 (仲裁失败后不进行通信)中添加描述 |
|                    | <mark>▼# I I I I I I I I I I I I I I I I I I I</mark>                  |

(6/7)

|               | (6/7)                                                                                                                               |  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------|--|
| 页码            | 描述                                                                                                                                  |  |
| pp. 490 ~ 492 | 在 <b>18.5.17 (6) 发生仲裁失败时的操作 (仲裁失败后不进行通信)</b> 的以下几项描述中添加 <b>(i) 当 WTIM0 = 0</b> 的描述                                                  |  |
|               | (f) 当要产生重启条件而由于低电平数据导致仲裁失败时                                                                                                         |  |
|               | (g) 当要产生重启条件而由于停止条件而导致仲裁失败时<br>(h) 当要产生停止条件而由于低电平数据导致仲裁失败时                                                                          |  |
| pp. 494~ 499  |                                                                                                                                     |  |
| pp. 494~ 499  | 修改图 18-27 主设备至从设备的通信举例(当主设备和从设备都选择 9 个时钟等待时)和图 18-28 从设备至主设备通信举例(当主设备选择 8 个时钟等待,从设备选择 9 个时钟等待时)                                     |  |
| 第十九章 乘法器/除    | 法器                                                                                                                                  |  |
| p. 508        | 修改图 19-7 除法操作(DCBA2586H ÷ 0018H)的时序图                                                                                                |  |
| 第二十二章 待机功能    |                                                                                                                                     |  |
| p. 531        | 修改 <b>22.1.1 待机功能</b> 的 <b>注意事项 3</b>                                                                                               |  |
| p. 533        | 修改 22.1.2 (2) 振荡稳定时间选择寄存器 (OSTS)中的描述                                                                                                |  |
| pp. 535, 536  | 在表 22-1 HALT 模式下的操作状态中添加时钟输出和蜂鸣器输出这一项,并添加注                                                                                          |  |
| p. 538        | 修改图 22-4 通过复位释放 HALT 模式                                                                                                             |  |
| p. 540        | 在表 22-3 STOP 模式下的操作状态中添加时钟输出和蜂鸣器输出这一项                                                                                               |  |
| p. 541        | 修改图 22-5 释放 STOP 模式时的操作时序                                                                                                           |  |
| p. 543        | 修改图 22-7 通过复位释放 STOP 模式                                                                                                             |  |
| 第二十三章 复位功能    |                                                                                                                                     |  |
| p. 546        | 修改图 23-2 通过 RESET 输入进行复位的时序                                                                                                         |  |
| p. 546        | 修改图 23-3 由于看门狗定时器溢出而复位的时序                                                                                                           |  |
| p. 547        | 修改图 23-4 通过 RESET 输入在 STOP 模式下复位的时序                                                                                                 |  |
| p. 548        | 在表 23-1 <b>复位期间的操作状态</b> 中添加时钟输出和蜂鸣器输出这一项                                                                                           |  |
| p. 551        | 修改 <b>表 23-2 响应复位后的硬件状态(3/3)</b> 的 <b>注</b> 中的表                                                                                     |  |
| 第二十四 上电清零电路   |                                                                                                                                     |  |
| p. 553        | 在 <b>24.1 上电清零电路的功能</b> 中添加对 <b>2.7</b> V/1.59 V POC 模式的描述                                                                          |  |
| p. 554        | 修改 24.3 上电清零电路的操作                                                                                                                   |  |
| p. 557        | 修改图 24-3 复位释放后软件处理举例 (1/2)                                                                                                          |  |
| 第二十五章 低电压检测电路 |                                                                                                                                     |  |
| p. 559        | 修改图 25-1 低电压检测电路的框图                                                                                                                 |  |
| p. 562        | 修改图 25-3 低电压检测等级选择寄存器 (LVIS)的格式                                                                                                     |  |
| p. 566        | 在图 25-5 低电压检测电路内部复位信号产生时序 (检测供电电压(Vpp)的等级)中添加(2) 在 2.7 V/1.59 V POC 模式下(选项字节: POCMODE = 1)                                          |  |
| pp. 570, 571  | 在图 25-7 低电压检测电路中断信号产生时序(检测供电电压(Voo)的等级)中修改(1) 在 1.59 V POC 模式下 (选项字节: POCMODE = 0),并添加(2) 在 2.7 V/1.59 V POC 模式下(选项字节: POCMODE = 1) |  |
| p. 573        | 修改图 25-8 低电压检测电路中断信号产生时序(检测外部输入引脚(EXLVI)的输入电压等级)                                                                                    |  |
| p. 575        | 修改图 25-9 复位释放后软件处理举例(1/2)                                                                                                           |  |
| 第二十六章 选项字节    |                                                                                                                                     |  |
| p. 577        | 在 <b>26.1 选项字节的功能</b> 中修改描述                                                                                                         |  |
| pp. 578, 579  | 修改 <b>图 26-1 选项字节的格式</b> 中的 <b>注</b> ,并添加对 0081H/1081H $\sim$ 0084H/1084H 区域的设置                                                     |  |
| p. 580        | 对用于设置选项字节的软件描述示例进行修改                                                                                                                |  |

|                              | (7/7)                                                           |  |
|------------------------------|-----------------------------------------------------------------|--|
| 页码                           | 描述                                                              |  |
| 第二十七章 闪存                     |                                                                 |  |
| p. 581                       | 在 <b>图 27-1 内存容量切换寄存器 (IMS)的格式</b> 中添加 <b>注意事项</b>              |  |
| p. 582                       | 在图 27-2 内部扩展 RAM 容量切换寄存器 (IXS)的格式中添加注意事项                        |  |
| p. 583                       | 修改表 27-3 78K0/KF2 系列 产品与专用闪存编程器之间的连线中的引脚数                       |  |
| p. 584                       | 修改图 27-3 3 线串行 I/O (CSI10) 模式下使用连线适配器对闪存进行写操作示例中引脚 1、2 和 11 的配线 |  |
| p. 585                       | 修改图 27-4 在 UART (UART6) 模式下使用连线适配器对闪存进行写操作示例中引脚 1、2 和 11 的配线    |  |
| pp. 586, 587                 | 修改 27.5 中(1) CSI10 和(2) UART6 的传送速率                             |  |
| p. 592                       | 修改表 27-7 通信模式 中速度栏的传送速率                                         |  |
| p. 594                       | 添加 <b>27.8 安全性设置</b>                                            |  |
| p. 598                       | 修改 <b>27.9.1</b> 引导交换功能                                         |  |
| 第二十八章 片上调试功能(仅用于μPD78F0547D) |                                                                 |  |
| p. 600                       | 该章的修订                                                           |  |
| 第三十章 电子产品规范 (目标系统)           |                                                                 |  |
| p. 615                       | 该章的修订                                                           |  |
| 第三十一章 封装图                    |                                                                 |  |
| pp. 635, 636                 | 添加封装图                                                           |  |
| 第三十二章 等待注意事项                 |                                                                 |  |
| p. 638                       | 修改表 32-1 产生等待的寄存器和 CPU 等待时钟数中 A/D 转换器的<产生最大/最小等待时钟数的条件>         |  |
| p. 639                       | 修改表 32-2 产生等待的 RAM 访问和 CPU 等待时钟数中等待时钟的个数                        |  |
| 附录 A 开发工具                    |                                                                 |  |
| p. 642                       | 在图 A-1 开发工具组成中添加(2) 当使用片上调试仿真器 QB-78K0MIN 时                     |  |
| p. 645                       | 添加 A.5.2 当使用片上调试仿真器 QB-78K0MINI 时                               |  |
| 附录 B 目标系统设                   | 附录 B 目标系统设计的注解                                                  |  |
| p. 647                       | 添加本章                                                            |  |
| 附录 D 修订历史                    |                                                                 |  |
| p. 657                       | 添加本章                                                            |  |
|                              |                                                                 |  |